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(57) Abstract 

The claimed data protection device (20) includes a processor (22) connected to a memory sy.-^tem (24) through an inicrconncciton 
mechanism (26). An input device (28) is also connected to the processor (22) and memory system (24) through the interconnection 
mechanism (26). The interconnection mechanism (26) i.*; typically a combination of one or more buses and one or more swiicbci. The 
output device (30) may be a display, and the input device (28) may be a keyboard and/or mouse or other cursor control device. 



FOK THE PURPOSES OF INFORMATION ONLY 



Codes used to identify Sates pany to the PCT on the front pages of pamphieis publishing international applications under the PCT. 



AL 


Albanu 


E5 


Spain 


LS 


Lesotho 


SI 


Slovenia 


AM 


Anncnit 


Fl 


Finlwd 


LT 


LJthuania 


SK 


SlovAta 


AT 


Aitstm 


Fit 


France 


LU 


Luxembourg 


SN 


Senegal 


AV 


Austrtlit 


CA 


Gabon 


LV 


Latvia 


S7. 


Swaziland 


AZ 


Azerteijin 


GB 


Uanol Ktagdom 


MC 


Monaco 


TD 


Chad 


BA 


BotBia ind Hesx^ovku 


GE 


Georfti 


MD 


Republic o( Mokiova 


TG 


Togo 


BB 


Biitedot 


GH 


Ghana 


MC 


Madijtaacar 


TJ 


Tajik i» an 


BE 


Belftutn 


GN 


Guinea 


Mk 


The ionner Yu|tosiav 


TM 


Turk men tsi an 


BF 


Burkint Fuo 


GR 


Greece 




Republic of Macedonia 


TR 


Turkey 


hO 


Buigirii 


HU 


iiuDgary 


ML 


Mall 


7T 


Trinidad and Tobago 


BJ 


Benin 


IE 


IreUnd 


MN 


Mongolia 


UA 


Ukraine 


BR 


Bnxil 


IL 




MR 


MtUTHania 


UC 


Uganda 


BY 


Beltrxis 


IS 


}ceUnd 


MW 


Malawi 


US 


Unned Siaiei or AmencA 


CA 


Cvudi 


IT 


Ualy 


MX 


Me&ico 


uz 


Uzbek at an 


CF 


Central Africvi Republic 


JP 


iapar 


NE 


Niger 


VN 


Vtei Nam 


CG 


Congo 


KE 


Kenya 


NL 


NcUierlandt 


YU 


Yugoslavu 


C»l 


Switzertftnd 


KG 


Kyrgytwan 


NO 


Norway 


zw 


/imbabwf 


CI 




KP 


Dtmociaiic People's 


HZ 


New /ealaml 






CM 


Camcnxm 




Republic of Korea 


PL 


Poland 






CN 


China. 


KR 


Republic of Korea 


PT 


Ponuga) 






CU 


Cubt 


KZ 


Kazakuan 


RO 


Romania 






CZ 


Cxcch Rcpublir 


LC 


Saint Lucia 


RL' 


KuutiJi Federation 






D£ 


Gemuny 


LI 


Lieclieuuein 


5D 


Sudar 






DK 


Denmart 


LK 


Sri Lanka 


SE 


Sweden 






LE 


Estoni* 


LK 


Liberia 


SC 


Singapore 







BnSDOCI^- <WC 9611690* ••_)_> 



wo 98/U690 



PCT/US97/16223 



- 1 - 



SELF-DECRYPTING DlCrTAL INFORMATION SYSTEM AND METHOD 

Field of the Invention 

The present invention is related lo mechanisms for protecting digital information from 
being copied. In particular, the present invention is related to mechanisms which permit 
authorized execution of computer program code or access to other digital information which is 
5 encr}'pted or otherwise encoded. 

Bs<?kgrowffd pf thy Unvgntwr 

A serious problem which faces the electronic publishing and software industries is the 
ease with which digital information can be copied without authorization from the publisher. 
10 Digital information also may be used or modified without authorization. For example, computer 
software may be reverse engineered or attacked by computer viruses. 

There are many mechanisms available which may be used to limit or prevent access to 
digital information. Such mechanisms often either restrict the ability of the user to make back-up 
copies or involve the use of special purpose hardware to limit access to tlie digital information. 
• 15 For example, some mechanisms restrict the use of digital information to a particular machine. 
See, for example, U.S. Patent 4,817,140. Other mechanisms require the digital information to be 
stored on a particular recording medium in order to be used. See, for example, U.S. Patent 
5,412,71 8. Yet other mechanisms allow only a certain number of uses of the digital information. 
See for example, U.S. Patent 4,888,798. Many of these access control mechanisms cause 
20 distribution to be more costly. 

Several other patents describe a variety of systems for encryption, compression, 
licensing and royalty control and software distribution such as: U.S. Pal. No. 4.405,829, U.S. 
Pat. No. 4,864,616, U.S. Pat. No. 4,888.800, U.S. Pat. No. 4,999.806, U.S. Pal. No. 5.021 .997. 
U.S. Patent No. 5,027,396, U.S. Pal. No. 5,033,084, U.S. Pat. No. 5,08 1 .675. U.S. Pat. No. 
25 5,155,847, U.S. Pat. No. 5,166,886. U.S. Pat. No. 5,191,611, U.S. Pat. No. 5.220,606, U.S. Pat. 
No. 5,222,133, U.S. Pat. No. 5,272,755, U.S. Pat. No. 5,287,407. U.S. Pat. No. 5.313.52]. U.S. 
Pal. No. 5,325,433, U.S. Pat. No. 5.327,563. U.S. Pat. No. 5,337,357. U.S. Pat. No. 5.351.293. 
U.S. Pal. No. 5,341.429. U.S. Pat. No. 5.351.297, U.S. Pat. No. 5,361,359. U.S. Pat. No. 
5.379,433, U.S. Pat. No. 5,392.351. U.S. Pat. No. 5,394.469, U.S, Pat. No. 5.414.850. U.S. Pai. 
30 No. 5,473.687, U.S. Pat. No. 5,490.216, U.S. Pat. No. 5.497,423. U.S. Pai. No. 5.509.074. U.S. 
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Pal. No. 5,.51 1,123, U.S. Pai. No. 5,524.072. U.S. Pai. No. 5.532.920. U.S. Pal. No. 5,555.304, 
U.S. Pal. No. 5,557,346, U.S. Pal. No. 5,557,765, U.S. Pal. No. 5.592,54<^. U.S. Pal. No. 
5,615.264, U.S. Pal. No. 5,625.692, and U.S. Pal. No. 5.638.445. 

Compuier programs or other digital informaiion also may be encr>'pied in order lo 

5 prevent an individual from making a useful copy of the information or from reverse engineering 
a program. Even with such encryption, however, a computer program must be decrypted in order 
for a compuier lo load and execute the program. Similarly, other digital informaiion must be 
decrypted before it can be accessed and used. Generally, digital information is decrypted lo disk, 
and not lo main memory of the computer which is more protected by the operating system. 

10 because decryption lo main memory results in a significant loss of memory resources. If the 
purpose for usmg encryption is to prevent users from copying the digital information, then 
decryption of the information to accessible memory for use dei'cals this purpose. 

One way to protect digital information using encryption has been made available by 
International Busmess Machines (IBM) and is called a *'CRYPTOLOPE" information container. 

15 This technology is believed to be related lo U.S. Patent Nos. 5.563.946 and 5,598,470 (to Cooper 
et ah), and published European patent applications 0679977, 0679978, 0679979 and 0681233. 
The CRYPTOLOPE system requires a user to have a "helper application" and a key. The 
CRYPTOLOPE informaiion container is generated by IBM. The content provider submits data 
to IBM, which in turn encrypts and packages the data in a CRYPTOLOPE information container. 

20 The helper application is a form of memory resident program, called a terminate and stay 
resident (TSR) program, which is a form of input/output (1/0) device driver insuUcd in the 
operating system and which monitors requests from the operating system for files on specified 
drives and directories. Because the TSR program must know the directory, and/or file name to 
be accessed, that informaiion also is available to other programs. Other programs could use thai 

25 information to manipulate the operation of the TSR program in order to have access to decrypted 
contents of the information container. The encrypted information container includes an 
executable stub which is executed whenever the application is run without the installed TSR 
program or from a drive not monitored by the TSR program to prcveni unpredictable activity 
from executing encrypted code. This stub may be used to install decr>piion and cause the 

30 application be executed a second time, or to communicate with the TSR program to instruct the 
TSR program to monitor the drive. It may be preferable from the point of view of the conieni 
provider however to maintain an encryption process and keys independently of any third party. 
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Multimedia content, such as a movie or hypertext presentation also may be stored on a 
digital versatile disk (DVD), sometimes called a digital video disk, compact disk read-only 
memory (CD-ROM), rev^iieable compact disks (CD-RW) or other medium in an encrypted 
digital formal for use with special-purpose devices. For example, concern about illegal copying 
5 of content from digital video disks or other digital media has resulted in a limited amount of 
content being available for such devices. This problem has caused representatives of both, 
multimedia providers and digital video disk manufacturers to negotiate an agreement on an 
encryption format for information stored on DVDs. This copy protection scheme is licensed 
through an organization called the CSS Interim Licensing organization. However, in this 

10 arrangement, the content provider is limited to using the agreed upon encryption format and a 
device manufacturer is limited to using a predetermined decryption system. 

Encryption has also been used to protect and hide computer viruses. Such viruses are 
typically polymorphic, i.e., they change every time they infect a new program, and are encrypted. 
The virus includes a decryption program that executes to decrypt the virus every time the 

1 5 infected program is run. Such viruses are described, for example, in '^Computer Virus- Antivirus 
Coevoluiion" by Carey Nachenberg, rnmmunicatinnj; of the ACM. Vol. 40, No. 1, (Jan. 1997), 
p. 46 et scq. Such viruses include decryption keys within them since, clearly, their execution is 
not carried out by the user and a user would not be asked for authorization keys to permit 
execution of the viruses. Additionally, such viruses are typically only executed once at the start 

20 of execution of an infected program and permanently return control to the infected program after 
execution. 

Summary of the Invention 

Some of these problems with digital information protection systems may be overcome 
25 by providing a mechanism which allows a content provider to encrypt digital information 

without requiring either a hardware or platform manufacturer or a content consumer to provide 
support for the specific form of corresponding decryption. This mechanism can be provided in a 
manner which allows the digital information to be copied easily for back-up purposes and to he 
transferred easily for distribution, but which should not permit copying of the digital information 
30 in decrypted form. In particular, the encrypted digital information is stored as an executable 
computer program which includes a decr}'piion program that decr>'pis the encr>'pted information 
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to provide the desired digital information, upon successful completion of an authorization 
procedure by the user. 

In one embodiment, the decryption program is executed as a process within a given 
operating system and decrypts the digital information within the memor\' area assigned to that 
5 process. This memory area is protected by the operating system from copying or access by other 
processes. Even if access to the memory area could be obtained, for example through the 
operating system, when the digital information is a very large application program or a large data 
file, a copy of the entire decrypted digital information is not likely to exist in the memor\' area in 
complete form. 

10 By encrypting information in this manner, a platform provider merely provides a 

computer system with an operating system that has adequate security to define a protected 
memor\' area for a process and adequate fijnctionality to execute a decryption program. The 
content provider in turn may use any desired encryption program. In addition, by having a 
process decrypt information within a protected memory area provided by the operating system, 

1 5 the decrypted information does not pass through any device driver, memory resident program or 
other known logical entity in the computer system whose behavior may be controlled to provide 
unauthorized access to the data. The ability to reverse engineer or attack a computer program 
with a computer virus also may be reduced. 

In another embodiment, the decryption program is part of a dynamically loaded device 

20 driver that responds to requests for data from the file containing the encrypted data. When the 
digiul information product is first executed, this device driver is extracted from the file and is 
loaded into the operating system. The executed digital information product then informs the 
loaded device driver of the location of the hidden information in the file, any keys or other 
passwords, and the name of a phantom directory and file to be called that only the digital 

25 information product and the device driver know about. The name of this directory may be 

generated randomly. Each segment of hidden information in the digital information product may 
be assigned its own unique file name in the phantom directory'. The digital information product 
then makes a call to the operating system to execute one of the files in the phantom director>'. 
The loaded driver traps these calls to the operating system, accesses the original file, decrypts the 

30 desired information and outputs the desired information to the operating system. 

In combination with other mechanisms that track distribution, enforce royalty payments 
and control access to decryption keys, the present invention provides an improved method for 
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idenlifying and delecting sources of unauthorized copies. Suitable authorization procedures also 
enable the digital information to be distributed for a limited number of uses and/or users, thus 
enabling per-use fees to be charged for the digital information. 

Accordingly, one aspect of the invention is a digital information product including a 
5 computer-readable medium with digital information stored thereon. The digital information 
includes computer program logic having a first portion of executable computer program logic 
and a second portion of digital information. The first portion of executable program logic, when 
executed, defines a mechanism for responding to requests for digital information from an 
operating system of a computer. This mechanism, when used to access the second portion of the 

)0 encrypted digital information, decrypts the encrypted digital information, and provides the 
encrypted digital information to the operating system. 

In the foregoing aspect of the invention, the digital information may be executable 
computer program logic. Hence, one aspect of the invention is a computer program product, 
including a computer readable medium with computer program logic stored thereon. The 

15 computer program logic includes a first portion of executable computer program logic and a 
second portion of encrypted computer program logic. The first ponion of executable computer 
program logic, when executed, defines a mechanism for responding to requests for computer 
program logic from an operating system of a computer. This mechanism accesses the second 
portion of encrypted computer program logic, decrypts the encrypted computer program logic, 

20 and provides the decrypted computer program logic to the operating system. 

Another aspect of the present invention is a computer program product, a computer 
system and a process which produce a computer program or digital information product in 
accordance with other aspects of the invention, using executable program code for the first and 
second portions of the desired computer program product. 

25 Another aspect of the present invention is a computer program product including a self- 

decrypting encrypted executable computer program. The product includes a computer readable 
medium having computer program logic stored thereon. The computer program logic defines 
first, second and third modules, wherein the third module defines the encrypted executable 
computer program. The first module, when executed by a computer, defines a mechanism Ibr 

30 loading the second module into memory of the computer. The second module, when executed by 
a computer, defines a mechanism for communicating with an operating system of the computer 
10 receive requests for program code from the encrypted executable computer program from the 
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third module, and for processing the requests lo access and decrypt the encrypted executable 
computer program and for providing the decrypted executable code from the third module to the 
operating sysiem. 

Another aspect of the invention is a process for executing encrypted executable 
5 computer programs on a computer system having a processor, memory and operating system. 
The process involves receiving computer program logic having a first module defining a start up 
routine, a second module, and a third module containing the encrypted executable computer 
program. The first module of the received computer program logic is executed using the 
processor. When the first module is executed, the second module is caused to be loaded into the 
10 memory of the computer system. Requests arc generated from the operating system for data 
from the encrypted executable computer program and arc received by the second module The 
second module accesses and decrypts the encrypted executable computer program in response to 
these requests and returns the decr>T)ted executable computer program to the operating system. 
These and other aspects, advantages and features of the present invention and its 
15 embodiments will be more apparent given the following detailed description. 

Brief Description of the Drawing 

In the drawing. 

Fig. 1 is a block diagram of a typical computer system with which the present invention 
20 may be implemented; 

Fig. 2 is a block diagram of a memory system in the computer system of Fig. 1 ; 
Fig. 3 is a diagram of a computer program or digital information product which may be 
recorded on a computer readable and writable medium, such as a magnetic disc; 

Fig. 4 is a flowchart describing how the computer program or digital information 
25 product of Fig. 3 is used; 

Fig. 5 is a flowchart describing operation of an example unwrap procedure as shown in 
Fig. 3 in one embodiment of the invention; 

Fig, 6 is a flowchart describing operation of an example device driver as shown in Fig 
3 in one embodiment of the invention; 
30 Fig. 7 is a block diagram of a computer system in the process of executing a computer 

program product in accordance with one embodiment of the invention; 
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Fig. 8 is a flowchan describing operation of an example unwrap procedure in another 
ennbodiment of ihe invention; and 

Fig. 9 is a flowchan describing how a computer program product such as shown in Fig. 
5 is constructed. 

s 

nctfliled Description 

The present invention will be more compielcly understood through the following 
detailed description which should be read in conjunction with the attached drawing in which 
similar reference numbers indicate similar structures. 

1 0 Embodiments of the present invention may be implemented using a general purpose 

digital computer or may be implemented for use with a digital computer or digital processing 
circuit. A typical computer system 20 is shown in Fig. 1. and includes a processor 22 connected 
to a memory system 24 via an interconnection mechanism 26. An input device 28 also is 
connected to the processor and memory system via the interconnection mechanism, as is an 

1 5 output device 30. The interconnection mechanism 26 is typically a combination of one or more 
buses and one or more switches. The output device 30 may be a display and the input device 
may be a keyboard and/or a mouse or other cursor control device. 

It should be understood that one or more output devices 30 may be connected to the 
computer system. Example output devices include a cathode ray tube (CRT) display, liquid 

20 crystal display (LCD), television signal encoder for connection to a television or video tape 

recorder, printers, communication devices, such as a modem, and audio output. It also should be 
understood that one or more input devices 28 may be connected to the computer system. 
Example input devices include a keyboard, keypad, trackball, mouse, pen and tabkt, 
communication device, audio or video input and scanner. It should be understood that the 

25 invention is not limited to the particular input or output devices used in combination with the 
computer system or to those described herein. 

The computer system 20 may be a general purpose computer system, which is 
programmable using a high level computer programming language, such as "C*^." "Pascal/' 
"VisualBasic." The computer system also may be implemented using specially programmed. 

30 special purpose hardware. In a general purpose computer system, the processor is typically a 
commercially available processor, such as the Pentium processor from Intel Corporation. Many 
other processors- are also available. Such a processor executes a program called an operating 
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system. such as Windows 95 or Windows NT 4.0, both available from Microsoft Corporation, 
which controls the execution of other computer programs and provides scheduling, debugging, 
input output control, accounting compilation, storage assignment, data management and memory 
management, and communication control and related services. Other examples of operating 
5 systems include: MacOS System 7 from Apple Computer. ()S/2 from IBM. VMS from Digital 
tquipmenl Corporation. MS-DOS from Microsoft Corporation. UNIX from AT&T, and IRIX 

from Silicon Graphics, Inc. 

The computer system 20 also may be a special purpose computer system such as a 
digital versatile disk or digital video disk (DVD) player. In a DVD player, there .s typically a 

1 0 decoder controlled by some general processor which decodes an incoming stream of data from a 
DVD. In some instances, the DVD player includes a highly integrated DVD decoder engine. 
Such devices generally have a simple operatmg system which may be modified to include the 
capabilities described and used hereiain connection with the typical operating systems in a 
general purpose computer. In particular, some operating systems are designed to be small 

,5 enough for installation in an embedded system such as a DVD player, including the WindowsCE" 
operating system from Microsoft Corporation and the JavaOS operating system from SunSoft 
Corporation. The operating system allows a content provider to provide its own programs that 
define some of the content, which is particularly useful for interactive multimedia. This 
capability also can be used to provide encryption and decryption, in accordance with the 

20 invention. 

The processor and operating system define a computer platform for which application 
programs in a programming language such as an assembly language or a high level programming 
language are written. It should be understood that the invention is not limited to a particular 
computer platform, operating system, processor, or programming language. Additionally, the 
25 computer system 20 may be a multi-processor computer system or may include multiple 
computers connected over a computer network. 

An example memory system 24 will now be described in more detail in connection with 
Fig. 2. A memory system typically includes a computer readable and writable non-volaule 
recording medium 40. of which a magnetic disk, a ftash memory, rewritcable compact disk (CD- 
30 RW) and tape are examples. The recording medium 40 also may be a read only medium such as 
a compact disc-read only memor>' (CD-ROM) or DVD. A magnetic disk may be removable, 
such as a "Ooppy disk'" or "optical disk." and/or peiroanem. such as a "hard drive " The disk. 
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which is shouTi in Fig. 2, has a number of tracks, as indicated at 42, in which signals are stored, 
in binary form, i.e., a form interpreted as a sequence of 1 's and O's, as shown ai 44. Such signals 
may define an application program to be executed by the microprocessor, or information stored 
on the disk to be processed by the application program. Typically, in the operation of a general 
purpose computer, the processor 22 causes data to be read from the non-volatile recordinc 
medium 40 into an integrated circuit memory element 46. which is typically a volatile random 
access memory, such as a dynamic random access memory (DRAM) or static random access 
memory (SRAM). The integrated circuit memory clement 46 allows for faster access to the 
information by the processor than disk 40, and is typically called the system or host memory. 
The processor generally causes the data to be manipulated within the integrated circuit memory 
46 and may copy the data to the disk 40, if modified, when processing is completed. A variety of 
mechanisms are known for managing data movement between the disk 40 and the integrated 
circuit memory 46, and the invention is not limited thereto. It should also be understood that the 
invention is not limited to a particular memory system. 
15 The file system of a computer generally is the mechanism by which an operating system 

manages manipulation of data between primary and secondary storage, using files. A file is a 
named logical construct which is defined and implemented by the operating system to map the 
name and a sequence of logical records of data to physical storage media. An operating system 
may specifically support various record types or may leave them uruiefined to be interpreted or 
20 controlled by application programs. A file is referred to by its name by application programs and 
is accessed through the operating system using commands defined by the operating system. An 
operating system provides basic file operations provided by for creating a file, opening a file, 
v^iting a file, reading a file and closing a file. 

In order to create a file, the operating system first identifies space in the storage media 
25 which is controlled by the file system. An entr>' for the new file is then made in a directory' 
which includes enuies indicating the names of the available files and their locations in the file 
system. Creation of a file may include allocating ceruin available space to the file. Opening a 
file returns a handle to the application program which it uses to access the file. Closing a file 
invalidates the handle. 

30 In order to write data to a file, an application program issues a command to the 

operaimg system which specifies both an indicator of the file, such as a file name, handle or 
other descriptor, and the information to be written to the file. Given the indicator of the file, the 
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operating system searches the director>' to find the location of the file. The directory entry stores 
a pointer, called the write pointer, to the current end of Uie file. Using this pointer, the physical 
location of the next available block of storage is computed and the information is written lo thai 
block. The write pointer is updated in the directory to indicate the new end of the file. 

In order to read data from a file, an application program issues a command to the 
operating system specifying the indicator of the file and the memory locations assigned to the 
application where the next block of data should be placed. The operatmg system searches its 
directory for the associated entry given the indicator of the file. The directory may provide a 
pointer to a next block of data to be read, or the application may program or specify some offset 
from the beginning of the file to be used, 

A primary advantage of using a file system is that, for an application program, the Hie is 
a logical construct which can be created, opened, written to, read from and closed without an> 
concern for the physical storage used by the operating system. 

The operating system also allows for the definition of another logical construct called a 
process. A process is a program in execution. Each process, depending on the operating system, 
generally has a process identifier and is represented in an operating system by a data structure 
which includes information associated with the process, such as the state of the process, a 
program counter indicating the address of the next instruction to be executed for the process, 
other registers used by process and memory management information including base and bounds 
registers. Other information also may be provided. The base and bounds registers specified for a 
process contain values representing the largest and smallest addresses that can be generated and 
accessed by an individual program. Where an operating system is the sole entity able to modify 
these memory management registers, adequate protection from access to the memor>' locations of 
one process from another process is provided. As a result, this memory management information 
is used by the operating system to provide a protected memor>' area for the process. A process 
generally uses the file system of the operating system to access files. 

The present invention involves storing encrypted digital information, such an audio, 
video, text or an executable computer program, on a computer readable medium such that ii can 
be copied easily for back-up purposes and transferred easily for distribution, but also such that it 
cannot be copied readily in decrypted form during use. In panicular. the digital information is 
stored as a computer program that decr>^pts itself while it is used to provide the digital 
information, e.g.. to provide executable operation code to the operating system of a computer, as 
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the digital information is needed. Any kind of encryption or decryption may be used and also 
may include authorization mechanisms and data compression and decompression. In one 
embodiment of the present invention, decrypted digital information exists only in memor>- 
accessible to the operating system and processes authorized by the operating system. When the 
5 digital information is a large application program, a copy of the entire decrypted application 
program is not likely to exist in the main memory at any given time, further reducing the 
likelihood that a useful copy of decrypted code could be made. The decryption operation also is 
performed only if some predetermined authorization procedure is completed successfully. 
One embodiment of the invention, in which the decryption program is a form of 

10 dynamically loaded device driver, will first be described. Fig. 3 illustrates the structure oi" digital 
information as stored in accordance with one embodiment of the present invention, which may 
be stored on a computer readable medium such as a magnetic disc or compact disc read only 
memory (CD-ROM) to form a computer program product. The digital information includes a 
first portion 50. herein called an unwrap procedure or application, which is generally 

15 unencrypted executable program code. The purpose of the unwrap procedure is to identify- the 
locations of the other portions of the digital information, and may perform other operations such 
as verification. In particular, the unwrap procedure identifies and extracts a program which will 
communicate with the operating system, herein called a virtual device driver 52. The unwrap 
procedure may include decryption and decompression procedures to enable it to 

20 decrypt/decompress the driver, and/or other content of this file. The program 52 need not be a 
device driver. The vinual device driver 52 typically follows the unwrap procedure 50 in the file 
container, the digital information. The virtual device driver, when executed, decrypts and 
decodes the desired digital information such as an executable computer program code from 
hidden information 54, which may be either encrypted and/or encoded (compressed), h is the 

25 decrypted hidden information which is the desired digital information to be accessed. This 
hidden information may be any kind of digital data, such as audio, video, text, and computer 
program code including linked libraries or other device drivers. 

In this embodiment of the computer program product, labels delineate the boundaries 
between the device driver and the hidden files. These labels may or may not be encrypted. A 

30 first label 56 indicates the beginning of the code for the vinual device driver 52. A second label 
58 indicates the end of the vinual device driver code. Another label 60 indicates the beginning: 
of the hidden information and a label 62 indicates the end of thai application. There may be one 
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or more blocks of such hidden information, each of which can be given a different name, li may 
be advantageous to use the name of the block of information in its begin and end tags. This 
computer program product thus contains and is both executable computer program code and one 
or more blocks of digital information. A table of locations specifying the location of each 

5 portion of the product could be used instead of labels. Such a table could be stored in a 
predetermined location and also may be encrypted. 

The overall process performed using this computer program product in one embodiment 
of the invention will now be described in connection with Fig. 4. This embodiment may be 
implemented for use with the Windows95 operating system and is described in more detail in 

10 connection with Figs. 5-7. An embodiment which may be implemented for use on the 

WindowsN'l' 4.0 operating system is described in more detail below in connection with Fig. 8. 
In both of these described embodiments, the digital information is an executable computer 
program which is read by the operating system as data from this file and is executed. The same 
principle of operation would apply if the data were merely audio, video, text or other information 

15 to be conveyed by a user. In the embodiment of Fig. 4, the computer program is first loaded 
into memory in step 70, and the unwrap procedure 50 is executed by the operating system, as any 
typical executable computer program is executed. The unwrap procedure may perform 
authorization, for example by checking for a required password or authentication code, and may 
receive any data needed for decryption or decompression, for example keys or passwords, in step 

20 72, Suitable authorization procedures may provide the ability to distribute software for single 
use. The unwrap procedure locates the virtual device driver 52 within the computer program in 
step 74, and then locates the hidden application in step 76. The virtual device driver 52 is then 
extracted by the unvwap procedure from the computer program, copied to another memory 
location and loaded for use by the operating system in step 78. An advantage of an operating 

25 system like Windows95 is that it allows such device drivers to be loaded dynamically without 
restaning the computer. 

The executed unwrap procedure 50, in step 80, informs the loaded virtual device driver 
52 of the location of the hidden information in the file, any keys or other passwords, and a name 
of a phantom directory and file to be called that only the unwrap procedure and the virtual device 

30 driver know about. The name of this phantom directory may be generated randomly. Each 
segment information hidden in the digital information product may be assigned its own unique 
file name in the phantom director}'. 
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After the loaded virtual device driver 52 receives all communications from the unwrap 
procedure, it opens the original apphcaiion file for read only access in step 82. The unwrap 
procedure then makes a call to the operating system in step 84 to execute the file in the phantom 
director)' for which the name was transmitted to the loaded virtual device driver. One function of 

5 the loaded virtual device driver 52 is to trap all calls from the operating system to access files in 
step 86- Any calls made by the operating system to access files in the phantom directory arc 
processed by the virtual device driver, whereas calls to access files in other directories are 
allowed to proceed to their original destination. In response to each call from the operating 
system, the virtual device driver obtains the bytes of data requested by the operating system from 

10 the original computer program file in step 88. These byies of data are then decrypted or 

decompressed in step 90 and returned to the operating system. When processing is complete, the 
phantom application is unloaded from the operating system in step 92, and may be deleted from 
the memory. 

A more detailed description of the process of Fig. 4 will now be described in connection 
15 with Figs. 5-7. Fig. 5 is a flowchart describing the operation of one embodiment of the unwrap 
procedure in more detail. The first step performed by this procedure is identifying the operating 
system being used, in step 1 00. This step is useful because different methods may be used with 
different operating systems. All code that may be used to run in various operating systems may 
be placed in this unwrap procedure. This procedure also may contain the 
20 decompression/decryption code, for example or any other computer program code to be - 
executed. 

The executed application then opens the original executable file as a data file and 
searches for the begin and end lags of the device driver and hidden files in step 102. The device 
driver code is copied into memory and loaded into the operating system in step 1 04. The unwrap 

25 procedure then informs the device driver of the name of the original application file, offsets of 
the hidden files and the name of a phantom director)', which is typically randomly generated 
(step 106). This communication may be performed using a "DevicelOConlror^ function call in 
the Windows95 operating system. The unwrap procedure then makes a call to the operating 
system to execute the hidden file in the phantom director)', in step 108. 

30 The operation of one embodiment of a device driver will now be described in 

connection with Fig. 6. After the device driver is loaded into the operating system, ii hooks into 
a position between the operating system and a file system driver CFSD), in step 1 10. to intercept 
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calls made by the operating system to the FSD for data from files in the phantom directon'. The 
FSD is the code within the operating system that performs physical reading and writing of data to 
disk drives. The operating system makes requests to the FSD for data from files in directories on 
the disk drives. The driver then receives information from the unwrap procedure including the 

5 name of the original file, the location of hidden files within the original file, and the name of the 
phantom directory created by the unwrap procedure (step 1 1 2). The device driver opens the 
original file as a read only data file. The device driver now traps calls, in step 114. made from 
the operating system for files in the phantom directory. Calls to other directories arc ignored and 
passed on to the original destination. The device driver then reads the data from the original data 

10 file, decrypts and decompresses it, and returns the decrypted/decompressed data to the operating 
system in step 116. 

For example, if the offset for the hidden application in the original data file is 266,270 
bytes and the operating system asks for 64 bytes starting al offset 0 of the hidden application in 
the phantom director)', the device driver reads 64 bytes from the original file starting at offset 

15 266,270, decrypts/decompresses those 64 bytes, and returns the first 64 decr>'pted/decompressed 
bytes back to the operating system. From the point of view of the operating system, the 64 bytes 
appear to have come from the file in the phantom directory. Steps 114 and 1 1 6 arc performed on 
demand in response to the operating system. 

A block diagram of the computer system in this embodiment, with a device driver 

20 loaded and in operation, will now be described in more detail in connection with, Fig. 7. Fig. 7 
illustrates the operating system 120, the loaded device driver 122, a file system driver 124. the 
original executable file 126 as it may appear on disk and the unwrap procedure 128. The 
executable file may in fact be on a remote computer and accessed through a network by the 
device driver. The unwrap procedure causes the operating system to begin execution of the 

25 hidden file by issuing an instruction to execute the file in the phantom director)', as indicated at 
1 30. This command is issued after the device driver 1 22 is informed of the file name of the 
original executable file 126, offsets of the hidden files within that file and the name of the 
phantom director)', as indicated at 132. The operating system then sians making calls to the 
phantom directory as indicated at 134. The device driver 122 traps these calls and turns them 

30 into requests 1 36 to the file system driver to access the original executable file 1 26. Such 

requests actually are made to the operating system 120, through the device driver 122 to the file 
system driver 124. The file system driver 124 returns encrypted code 138 to the device driver 
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122. The encrypied code 138 actually passes back through the device driver 122 lo the operating 
system 120 which in turn provides the encrypted code 138 to the device driver 122 as the reply lo 
the request 1 36 for the original file. The device driver 122 then decrypts the code to provide 
decrypted code 140 to the operating system 120. 

5 Another embodiment of the invention will now be described in connection with Fig. 8. 

This embodiment may be implemented using the WindowsNT 4.0 operating system, for 
example, in this embodiment, the device driver portion 52 of the computer program product is 
not used. The unwrap procedure for this embodiment begins by identifying the operating system 
being used similar, which is step 100 in Fig. 5. If the operating system is Windows NT 4.0, for 

10 example, a different unwrap procedure for this embodiment is performed. Before describing ihis 
unvsrap procedure, a brief description of some of the available operating system commands will 
be provided. 

Currently, under all versions of the Window operating system or operating environment 
from Microsoft Corporation (such as Windows 3.1, Windows 95 and Windows NT 3.51 and 4.0) 

15 all executable files (.exe) or dynamic link library (.dll and .ocx) files, which are executable files 
with different header and loading requirements than .exe files, that arc loaded into memory by 
the operating system must reside as a file either locally, e.g., on a disk drive or remotely, e.g.. 
over a network or communications port. All further references herein to loading an executable 
will be using the Win32 function calls used in Windows 95 and NT 3.51 and 4.0 operating 

20 systems. The CreateProcessO function which loads files with an .exe extension takes ten 
parameters: 



BOOL CreateProcess(// Prototype from Microsoft Visual 

LPCTSTR IpApplicationName, 
25 LPTSTR IpCommandLine, 

LPSECURTTY^ATTRIBUTES IpProcessAuribuies, 

LPSECURITY_ATTRIBUTES IpThrtadAttribum, 

BOOL binheriiHandles, 

DWORD dwCreaiionFlagSy 
30 LPVOID IpEnvironmem, 

LPCTSTR IpCurremDireaory, 

LPSTARTUPINFO IpStanupJnfo, 

LPPROCESS INFORMATION ipProcesslnformaiion 



C++ Help Documentation 
// pointer to name of executable module 
// pointer lo command line string 
// pointer to process security atiribuies 
// pointer lo thread securiiy aitribuies 
// handle inheritance flag 
// creation flags 

// pointer lo new environment block 
// pointer lo current direciorv' name 
// pointer to STARTUPINFO 
// pointer lo PROCESS_INFORM ATION 



); 
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Three of these parameters arc pointers to strings that contain an application file name, command 
line parameters, and the current directory. The other parameters are secunt>\- environmental, and 
process infonnation. The LoadLibraryO function takes one parameter that is a pointer to a string 
thai contains the application file name: 

5 

HTNSTANCE LoadLibrary(// Proioiype from Microsoft Visual C + + Help Documcmauon 
LPCTSTR IpLibFileName II address of rilename of execuiablc module 
); 

10 The LoadLibraryExO function takes three parameters the first being the same as LoadLibrary( ). 
the second parameter must be null, and the third tells the operating system whether to load the 
file as an executable or as a data file in order to retrieve resources such as icons or string table 
data from it and not load it as an executable: 

15 HINSTANCE LoadLibraryEx(// Prococypc from Microsoft Visual C+ + Help Documcmaiion 
LPCTSTR IpUbFileName, If points to name of executable module 
HANDLE hFiUl H reserved, must be NULL 

DWORD dwFlags II entry-point execution flag 

); 

20 

The CreateFileO function is used to create and open files and to load files such as device drivers 
This function also requires a pointer to a siring thai contains the name of a physical file: 

HANDLE CreateFae(// Protoiypc from Microsoft Visual C + + Help I>ocumemaiion 

25 LPCTSTR IpFileName. Poi^^r lo name of the file 

DWORD dwDtsiredAccess, access (rcad-write) mode 

DWORD dwShareMode, share mode 

LPSECURTTY ATTRIBUTES IpSecuriryAitributes, II pointer to security descripror 

DWORD dwCreationDisthbution, H how lo create 

30 DWORD dwFlagsAndAtrhbutes, H file attributes 

HANDLE hTempiateFile ^' handle to file with attributes lo copy 
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There are other functions such as MapViewOf?ile() and MapViewOfFiieEx() thai map areas of 
memory lo an already opened physical file through a handle to that file. They have the following 
parameters: 



10 



LPVOID MapViewOfFilc(// Prototype from Micrdsofi Visual C+ + Help Documcniaiion 
HANDLE hfileMappingObjecu // file-mapping objcci to map inio address space 

DWORD dwDesiredAccesSj II access mode 

DWORD dwFileOffsetHigh, II high-order 32 bits of file offsei 

DWORD dwFileOffsetLow, II low-order 32 bits of file offsci 

DWORD dwNumberOfByiesToMap II number of byies to map 



); 



LPVOID MapViewOrFileEx(// Prototype from Microsoft Visual C + + Help Documcntaiion 
HANDLE HFileMappingObjea, II file-mapping objcci lo map inio address space 

1 5 DWORD dwDesiredAccess, II access mode 

DWORD dwFileOffseiHigh, II high-order 32 bits of file offset 

DWORD dwFileOffseiLow, If low-order 32 bits of file offsci 

DWORD dwNumherO/ByiesToMap, II number of bytes lo map 
LPVOID IpBaseAddress II suggested starting address for mapped vic^^' 

20 ); 

All of the foregoing functions directly use a pointer to a string that is a physical file. The only 
file functions that do not directly use a physical filename are functions like CreateNamcdPipc(). 
which has the following parameters: 
25 HANDLE CreateNamedPipe(// Prototype from Microsoft Visual C+ + Help Documentation 
LPCTSTR ipName, II pointer to pipe name 

DWORD dwOpenMode, J I pipe open mode 

DWORD dwPipeMode, II pipe-specific modes 

DWORD nMaxInstances, II maximum number of instances 

30 DWORD nOutBufferSiie, II output buffer size, in bytes 

DWORD ninBufferSize, II input buffer size, in byics 

DWORD nDefouUTimeOui, II time-out time, in milliseconds 

LPSECURrrV_ATTRIBUTES IpSecuriryAttributes II pointer to security attributes siructure 
); 
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The siring to which CrealeNamedPipe() points using the first parameter is a siring that both an 
existing executable and the operating s>'steni know about and does not exist physically. 
Unfortunately both of the executables that "know" this private name could only be loaded usmg 
one of the other procedures that required a physical file. Currently ii is not possible to load an 
5 executable using a "named pipe" name. Both of or any executables thai use the name of the 
"named pipe" already must have been loaded into memor>'. 

All of the foregoing functions require a physical file because all of them use "file 
mapping" processes. File mapping allows large executable files to appear to be loaded rapidly 
since they are rarely completely loaded into memory but rather arc mapped into memor>' The 
U) detriment to this mapping capability is that executable code must remain in physical memor>' in a 
file in unencrypted form in order to be loaded, unless there is a middle layer or file system driver 
that the operating system uses as a physical layer and that dccr>Tis the executable code to the 
operating system on demand. The potential weakness here is that another file system driver can 
hook into the operating system to monitor traffic between the operating system and all file 
1 5 system drivers and capture decrypted executable code passing from the file system driver to the 
operating system. Some operating systems allow such monitoring more than others. Many anti- 
viral software packages use this technique to prevent computer virus attacks. 

One method of loading and executing encrypted executable computer program code is to 
use a stub executable having two parts. The first pan is the normal from end loader code that all 
20 executables have. In addition, the first pan would perform any authorization which may include 
receiving a password from the user, then allocate enough memor>' to hold hidden encrypted code 
when it is decrypted, either in its entirety or a portion of ii, copy the encrypted code into that area 
of protected (and preferably locked so no disk swapping occurs) memory, decrypt it once it is in 
memory and only in memory, and then have the operating system load the code only from 
25 memory therefore bypassing any file system drivers or TSRs so they have access to only 
encrypted code. 

Some of the file functions listed above and similar functions on other operating systems 
could be modified easily by a programmer having access to source code for those operating 
systems, or a new operating system may be made to provide functions which allow direct loading 
30 of executable code from memory rather than physical files. For example, in the Win32 

commands, a command similar to CreateProcessO command could be provided. The command 
should have a few extra parameters including the process identifier of the process that comain.s 



BNSDOCID <WC &e*.i690Ai_._> 



wo 98/11690 PCT/US97/16223 

.19- 

ihe now decrypted executable code, the memory address of the start of the decrypted code, and 
the size of the decrypted code. The command could also contain a parameter specifying a "call 
back" function within the first process that would provide decrypted code on demand directly lo 
the operating system through a protected buffer, therefore allowing only a portion of the 
5 encr>'pted code to be decrypted at any one time instead of in us entirety, for better protection and 
less memory use. The second parameter of the LoadLibraryEx() command thai now needs to be 
NULL could be expanded to hold a structure that contained the same information. Both of these 
and other similar functions could be changed or created to allow loading executable code either 
as an .exc, .dll, or other extensions or identifiers, such as by using a "named pipe" name thai onl> 

10 the operating system and process that holds decrypted code know about and having the operating 
system load from the named pipe. 

Alternatively, without having such additional capabilities in the operatmg system, an 
application program can be divided into two parts. The first part is code that is common to all 
applications such as code for allocating memory off the heap and code that provides some 

i 5 interaction with the user. This kind of code is generally not code that the content provider is 
concerned about copying. The second part is the code that the content provider believes is 
valuable. Typically this valuable code is a business logic code or what would be considered a 
middle tier of a three-tier environment. A content provider would like to protect this second part 
of the code, at least much more that the first part of the code. The content provider would place 

20 all of the important code to be protected inside a dynamic link library and the code that is not thai 
important would reside in the front end "stub" executable. Both of these would be combined into 
another executable containing the .dll in encrypted form only, along with any other files, data, 
information, and/or tables for holding, for example, hardware identifiers. This other executable 
is the final digital information product. 

25 The first part of the digital information product, i.e., the executable stub, would load and 

execute normally like any other application. It then would perform any authorization procedures. 
Once the proper authorization or password was completed successfully, an unwrap procedure 
would be performed as will now be described in connection with Fig. 8. it would then allocate 
enough protected memory using a function like VirtuaiAlloc() as shown in step 1 50: 

30 

DWORD nFileSize = 0; 
DWORD nPhantomPileSize = 0; 
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DWORD exeOffset = 0; 

DWORD nPreferrcdLoadAddress = GelPreCompiledLoadAddress(); 

CSiring cCommandFile = UnwrapGetNTCommandFile(): 

exeOffsei = UnwrapGetDllOffset( cCommandFile); 

nFileSize = UnwrapGelDlISize(cCommandFile); 

nPhantomFileSize = nFileSize + 0x3000; // add any needed extra space 

// Increase buffer size to account for page size (currently Iniel page size). 

DWORD nPageSize = GetPagcSize(); 

nPhantomFileSize ^= (nPageSize -(nPhantomFileSize % nPageSize)); 
// Allocate the memory lo hold the decrypted executable. 
LPVOID IpvBlock = VirtualAlloc((LPV01D) nPreferrcdLoadAddress. 
nPhantomFileSize. 

MEM_RESERVE | MEM.COMMIT. PAGE_READWR1TE); 

This function can request a particular address space. Preferably, this address space is the 
preferred load address space to which the .dll was linked in order to minimize any needed 
relocation and fix up code. The stub executable may lock that area of memory in step 1 52. for 
example by using VirtualLockO to prevent any memor>' writes io a swap file, depending on the 
operating system, as shown below: 

BOOL bVLock = VirtualLock((LPV01D) nPreferrcdLoadAddress. nPhantomFileSize); 

The memory area still should be secure even without this preventive step since the Windows 95 
and NT operating systems do not allow any user access to swap files. 

The encrypted code is then copied from the digital information product into the allocated 
protected memory in step 154, for example by using the following command: 

UnwrapCopyHiddenExeToMem(cCommandFilc, exeOffsei. nFileSize. (char *) IpvBlock): 

0 

Once in memory, the stub would then decrypt the code to thai same ponion ol memor>' in step 
156. for example by using the following commands: 
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CwrapDecryptSeed(cPassworci.GelBuff€r(0), cPassword.Getl.engih()); 
CwrapDecrypi({ unsigned char *) ipvBlock, 0, nFiieSize); 



Any "fix up and relocation" type services would then be performed in step 1 58, for example by 
5 using the foliowing command: 

UnwrapFixUpAndRelocateDII(lpvBlock); 

Possibly, the memory protection may be changed to execute only in step 160. for example by 
10 using the VinualProieci() command as follows: 

DWORD IpflOldProteci; // variable to get old protection 
BOOL bVProteci = VinualProtect((LPVOID) nPreferredLoadAddress, 

nPhantomFileSize, 

15 PAGE.EXECUTE, 

&lpfl01dProtect); 

Function calls then can be made into that area of memory that now contains the decrypted code: 

20 UnwrapDoDllAlgorilhmsO; 

Some of the "fix up" operations to be performed above include placing the addresses of external 
or stub.exe functions into the address place holders of the decrypted .dll or iniemai code, by 
using commands similar to the following: 

25 

Write Address((char*) 0x0a406i04, (DWORD) &CallBackFunclionl); 
Write Address( (char*) 0x0a406100, (DWORD) iS:CallBackFunction2); 

For instance a wrapper function could be created in the outer stub.exe that received a size 
30 parameter, allocated that amount of memory off of the heap, and passed back the staning address 
ofthat block of memory. Another example would be to have encrypted algorithms within the 
hidden. encr>'pted .dll which would be called at run time from the front end stub once decr>'picd 
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wiihin proiecied memory. The dynamic link librar>' would be compiled and linked lo expect a 
poinier lo a function that took that parameter and/or returned a value by including prototypes in 
the header file as follows: 



5 void (*lpCallBackFuncl)(); 

void (♦|pCallBackFunc2)(unsigned long); 

Function calls to "external" functions also could be added as follows: 

10 (♦IpCallBackFuncDO; 
unsigned long z = x * x; 
(♦lpCallBackFunc2K2); 

At run time the "fix up" code would lake the run lime address of that "wrapper function" . and 
15 place it into the pointer address wiihin the .dll block of code as follows: 

WriteAddress((char*) 0x0a406104, (DWORD) &CallBackFunctionl ): 
Write Address((char*) Ox0a406100, (DWORD) &CallBackFunction2); 

20 This information is readily available using the .cod output files from the compiler, an example of 
which follows: 

^TestSum PROC NEAR ^ COMDAT 

: Line 8 

25 00000 56 push esi 

; Line 23 
00001 * ff 15 00 00 00 

00 call DWORD PTRJpCallBackFuncl 

; Line 24 

30 00007 8h 44 24 08 mov eax. DWORD PTR.a$[esp] 

0000b 50 push eax 

0000c e8 00 00 00 00 call _TestSquare 



10 



15 



20 



25 



30 
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00014 
: Line 25 

00016 

0001a 

0001b 

00020 

00023 
; Line 28 

00025 

00026 
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83 c4 04 
8b fU 



add esp, 4 
mov esi, cax 



8b 44 24 Oc mov eax, DWORD PTR^b$[esp] 



50 

e8 00 00 00 00 call 
83 c4 04 add 



03 c6 

5c 
c3 



push eax 

_TeslSquarc 
esp, 4 
eax, esi 



add 

pop 
rel 



esi 

0 



_TcstSum ENDP 

^TEXT ENDS 

; COMDAT_TestSquare 

_TEXT SEGMENT 

_xS = 8 

_TesiSquarc PROC NEAR 
; Line 30 

56 push esi 



COMDAT- 



00000 
: Line 32 

00001 

00005 
: Line 34 

00008 

00009 

00 

O000f83 c4 04 
00012 8b c6 

: Line 36 

00014 5e 

00015 c3 
JFeslSquare ENDP 



8b 74 24 08 mov esi, DWORD PTR _x${esp] 

0faff6 imul esi, esi 

56 push esi 

fflSOOOOOO 

call DWORD PTR _lpCaliBackFunc2 
add esp, 4 

mov eax, esi 



pop 
ret 



esj 

0 
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Such information also is available from .map output files from the linker where the between 
the address (i.e.. 0a406100) and the object file (i.e. Algorithms. obj) means it is a "flat" address 
(i.e.. hard coded by the linker) and the lack of an "P means that it is an address pointer lo be 
supplied at run time (load time) where the address that is contained in that address location is 
5 used and not the actual address location (i.e.. the address that is contained ai address location 
0a406100 and not 0a406100 itselO: 



0001:00000000 
0001:00000030 



Tests um 
TestSquare 



0a401000 f Algorithms.obj 
03401030 f Aleorilhms.obj 



0003:00001100 
0003:00001 104 



JpCalIBackFunc2 
JpCaliBackFuncl 



0a406100 Aigorithms.obj 
0a406 1 04 Algorilhms.ob j 



When the code inside the .dll makes a "call" to a dereferenced pointer, it would jump to the 
15 correct function in the outer code and return the expected return value (if any). For example: 



void CallBackFunctionl(){ 

// This is the first function that exists in the Stub executable 
// whose address has been placed at the appropriate location inside the "dll" code 
20 // that has now been decrypted in a block of memory. The code inside the "dll" 

// makes a function call to this function. In its encrypted state, the "dll" docs not contain 
// this address, but merely has a placeholder for the address. The *^dH" has enough space 
allocated to hold an 

// address of this size. After the "dlf has been decrypted at run time, ius address is 
25 // placed in that location so the code inside the "dll" that references (or more 

// appropriately dereferences) that address can jump (which is function call) to this 

// address. 

AfxMessageBox( 

_T("This is the FIRST Stub.exe call back function being called from the d!l.")); 
30 return: 
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void CallBackFunction2(DWORD nNumber){ 

// See comment for CallBackFunctionl except this function receives a parameter off 
// of the Slack. It could also return a value as well. 

CSiring 

cString( 

TC'This is the SECOND Stub.exe call back function being called from the dll")); 



harbuffer[20]; 
lioa(nNumber. buffer, 10); 

10 

cString _T(*' with a parameter of*'); 
cString buffer: 
cString+=_Tr."); 

AfxMessageBox(cString.GetBuffer(0)); 
15 return; 



The outer stub.exe would make the same kinds of jumps or function calls into the now protected 
decrypted code block as follows: 

20 

DWORD c; 



// This comm^d declares a function pointer. This command is different for different function 
// calls. Here the called function takes two integer parameters and 
2 5 // passes back a D WORD . 

DWORD (*lpFunc)(DWORD,DWORD); 



// The function pointer is then pointed to the staning address of the function in the 
// block of memory that now holds the decrypted DLL, 
30 IpFunc = (DWORD (*)(DWORD,DWORD)) UnwrapFixUpAndReiocaieDlK ): 

//Now call that "function" which is really like all function calls, i.e., a jump to 
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// the address where that function exists. In this case, two 

// variables are passed to that function and returning a value from that function. This function 
illustrates that the function call 
// can be more complicated than merely a simple jump 
5 // 10 an address. Inline assembler code may be used to push the variables onto 

// the stack frame and return the variable from the eax register, but this function enables 
// the C++ compiler to do the same function, 
c = (DWORD) (♦lpFunc)(a, b); 

10 This mechanism requires the unwrap procedure and the now decrypted code lo have intimate 
knowledge about procedural interfaces of each other but no knowledge about each other's 
implementation. This is the way most executable .exe files and .dll files behave but with the 
addition of a scries of "wrapper" functions on either side for communication. This method works 
under Windows 95 and Windows NT 4.0 operating systems and should work under Windows NT 

15 3.5 1 and other operating systems. 

Another modified version of this mechanism that works under the Windows NT 4.0 
operating system because of functions specific to Windows NT 4.0 would be to have another 
hidden and/or cncr>'pted executable within the digital information product. This executable 
would be copied to a physical disk in an unencrypted form, launched or loaded with the 

20 CreateProcess( ) command in its current form but called with a parameter to load the executable 
in suspended mode: 

BOOL success = CreateProcess(cFrontEndExe.GetBuffer(0), 0, 0, 0. TRUE, 
CREATE_NEW_CONSOLE | CREATE_SUSPENDED, 
25 0. 0. &startUpInfo, &processinfo); 

Then the first process would copy the encrypted dll into its own process and decr>'pt it. allocate 
enough memory using Virtual AllocEx() in its current form in the second process that has just 
loaded the expendable front end executable in a suspended state as follows: 

30 

LPVOID IpvBlockEx = Virtua]AllocEx(processlnfo.hProcess. 
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(LPVOID) nPreferredLoadAddress. nPhaniomFileSize. 
MEM_RESERVE | MEM_COMMIT, 
PAGE^READWRJTE); 

The decrypted code is copied from the first process to the second suspended process using 
WriteProcessMemoryO in its current form: 

BOOL bWriteProcessMemory = WriieProcessMemory<(HANDLE) processlnfo.hProcess, 
(LPVOID) ipvBlockEx, (LPVOID) n Preferred Address, 
(DWORD) nPhantomFileSize, (LPDWORD) &nBytes Written); 

The primary thread of the previously launched second process is then resumed: 

DWORD nResumed = ResumeThread(processlnfo.hThread); 

Any necessary function pointers are then placed in the correct locations by the second process, 
the area of memory is locked to prevent any writes to a swap file, and the memor>' protection is 
changed to execute only as follows: 

WriteAddress((char*) OxOa406]04, (DWORD) &CallBackFunclionl); 
Write Address((char*) 0x0a406100. (DWORD) &CanBackFunciion2); 

BOOL bVLock = VirtualLock((LPVOID) nPreferredLoadAddress. nPhantomPileSize); 

DWORD IpflOldProiect; // variable to get old protection 

BOOL bVProiect = VirtualProiect((LPVOID) nPreferredLoadAddress, 

nPhaniomFileSize, PAGE^EXECUTE, &lpfl01dProiect); 

The program can continue running by making and receiving calls to and from the decrypted 
dynamic link library, that now resides in the protected memorv' of its process usmg commands 
such as the following: 

DWORD c; 
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DWORD (MpHunc)(DWORD,DWORD); 

IpFunc = (DWORD (*)(DWORD,DWORD)) ExpendabieGeiEntry Address!): 
c = (DWORD) ClpFuncXa, b); 

5 The first process can eilher close down or launch another instance of that same process. 

In either of these implcmentalions using the same process or launching into a second 
process, the hidden encrypted code never passes through a file system driver or memorv' resident 
program in decrypted form. Code can be split up among different dynamic link libraries so that 
no two would reside in memory at the same time in order lo protect code further. Both of these 
10 systems can be implemented using the Win32 function calls. If additional functions, similar lo a 
CreateProccssO command or a LoadLibraryO command but that lake a process identifier and 
address location in memory to load in an executable instead of a physical file, are provided m an 
operating system then the entire executable and dynamic link library can be hidden, encrypted, 
and protected on the physical disk and then decrypted within protected memor>' and use the 
15 operating system loader to load it directly to the operating system from memory without residing 
in deciypied form on any physical medium. 

Having described the operation and use of the computer program product in accordance 
with the invention, embodiments of which are described above in comiection with Figs. 3-8. and 
the operation of the unwrap procedure and device driver it contains, the process of constructing 
20 such a computer program product will now be described in more detail. Referring now to Fig. 9, 
an embodiment of this process for creating a computer program product is shown. This process 
can be applied to any digital information includmg an arbitrary executable xompuier program, 
dynamic link libraries and related files of data. All digital information is treated as mere data by 
this process. Each separate data file is combined into a single file by this process, with an 
25 executable program for performing the unwrap procedure, and optionally executable program 
code for a virtual device driver, into the computer program product. Each file of hidden 
information has a unique location and is identified by its own begin and end markers as shown in 
Fig. 3. The first step of this process is opening a new data file for the computer program using a 
name that will be used to indicate an executable file (step 200). For example, an executable 
30 word processing program may be named "word_processor.exe"" in the Windows95 operating 
system. 
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The three portions of the computer program product are then inserted into the open data 
file. First, the unwrap procedure is inserted ai the beginning of the file in an execmable format in 
step 202. The begin tag for the optional device driver is then inserted in step 204. The 
executable device driver program code is then inserted in step 206, followed by its conesponding 
5 end tag in step 208. For each hidden file to be inserted into this computer program product, siep.s 
2 1 0 to 2 1 6 are performed. First, the begin tag is inserted in step 2 1 0. The begin tag also may 
include an indication of a unique name of the file which will be used as its name in the phantom 
directory created by the unwrap procedure. The hidden file is then encrypted and/or compressed 
in step 2 1 2 and inserted into the data file in step 214. The end tag for the hidden file is then 

10 inserted in step 2)6. The device driver and all of the tags may be encrypted also if the unwrap 
procedure has suitable decr>'ption procedures. The computer program file is closed when the last 
hidden file is processed. 

Using the present invention digital information, such as executable program code or 
various kinds of data, is loaded and unloaded as needed, and thus does not take up any more 

15 memory than is necessary. At no time does unencrypted digital information, such as computer 
program code, exist on disk in accessible and complete decrypted form. Because the original 
digital information is available as a read only file in one embodiment of the invention accessible 
only to the device driver, the digital information may be accessed over networks, from a CD- 
ROM or from a DVD, and can be made to have a limited number of uses. This mechanism is 

20 particularly useful for controlling distribution of computer programs, digitized movies or other 
information while reducing the cost of such distribution and control. For example, software may 
be distributed over a network on a single use basis, and charges may be levied on a per use basis. 
The ability to reverse engineer an application program also may be reduced. 

One benefit with this system over some other systems for preventing unauthorized access 

25 to digital information is that the content provider maintains control of the encryption applied to 
the information how it may be decrypted. Any need for either a centralized facility or a 
predetermined decryption program is eliminated. An operating systems manufacturer or other 

^ ^ platform vendor merely provides the capability for the information to be accessed and decrypted 
on the fly. Since the valuable information and any other tables of authorization codes, 

30 passwords, or hardware identifiers that the content provider may use to secure the informaiion 
resides in one large encrypted file, it becomes difficult, if not impossible, for someone to 
determine just where any of this informaiion exists. 
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A potential scenario with authorization procedure in which the present invention may he 
used is the following. A consumer purchases a DVD disk containing a movie. The user puts the 
disk into the player. This is the first time the disk is installed. The coniem provider's functions 
are loaded into the DVD chip, which looks in the encrypted table and sees that this is the first 

5 lime this disk is being played. The player then displays on a screen a numeric identifier and toll 
free phone number. The consumer calls the toil free phone number and inputs the numeric 
identifier that was displayed on the screen. The content provider provides a numeric password 
based on the numeric identifier that the user inputs into the DVD. The content provider may 
develop a database of information about its consumers that also may be used to detect pirating of 

10 the digital information product. Now that this authorization has taken place, the software that the 
content provider wrote, and is now in the DVD chip, lakes a hardware identifier from the DVD 
and encrypts it and puts it in the encrypted and buried table on the disk. Alteratively, the data 
may be decrypted in memory and re-cncrypied back onto the disk using the hardware identifier 
as pan of a key. Now that disk will run and show the movie and will only run on that DVD and 

15 no other. The content provider could allow for a table of hardware id's so they could limit the 
number of DVD's that disk would run on or a limited number of times it can be shown. It should 
be understood that many other authorization procedures may be used. 

In the foregoing scenario, the movie is encrypted on the same disk inside of the encrypted 
file that contains the table and functions the content provider distributed. The movie is decrypted 

20 by the decryption functions contained in the file directly to the DVD chip. At no time does the 
movie reside anywhere in decrypted form. The content provider can protect the movie with any 
desired level of security (for both encryption and authorization). 

In the present invention, the onus of protection of content does not reside with a hardware 
manufacturer or platform provider but in the hands of the content provider. The hardware 

25 manufacturer only provides the mechanism to protect the digital information through the 

operating system. The technique and implementation of protection resides in the hands of the 
content provider. This mechanism allows the content providers to change the level of security as 
needed without any modifications to the hardware. The security of the content is provided by the 
encryption/decryption algorithms, public/private keys, and authorization methods which are 

30 determined by the content provider. Even each individual product can have its own 

encryption/decryption algorithms and/or public/private keys. All of these can be changed and 
enhanced as the market demands. 
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The present invention also could be used for on-line or live use of digital information. 
For example, a movie could be retrieved on demand and recorded by a consumer. A set lop box 
could receive the digital information, decrypt it, and then re-encrypi and store the information 
using, for example, a hardware identifier of the set top box. Since home movies digitally 
recorded would be encrypted using the hardware identifier of the device used in recording, thai 
home movie could not be played on another or only on a limited number of other devices and/or 
for only a specified number of times depending on the wishes of the content provider. Since the 
algorithms are downloaded at the time of recording from a service provider, e.g., the cable 
company, the content provider (movie company) would provide the encrypted data to the service 
provider to present to their customers. The service provider need not be concerned with the 
encryption/decryption and authorization functions used by the content provider. Similar uses are 
possible with other data transmission systems including, but not limited to, telephone, cellular 
communications, audio transmission including communication and the like. ; 

In another embodiment, the stub executable program is a first process that is implemented 
similar to a debugging tool such as the Softlce debugger from NuMega Technologies or the 
WinDebug debugger from Microsoft Corporation for Ring 0 kernel level debugging for an Intel 
processor based architecture, or the CodeView debugger for ring 3 application level debugging. 
Such a debugger controls execution of a program to be debugged as a second process and steps 
through each program statement or opcode of the debugged program. The debugging tool could 
be modified to monitor each opcode that indicates a jump to a program fragment, such as each 
instruction or a block code. If the program fragment to be executed is not decrypted, the 
modified debugger decrypts the program fragment before the jump command is allowed to 
execute. Each program fragment may be re-encrypted after execution. Clearly, unnecessar\' 
debugging commands may be omitted from the modified debugger. 

Having now described a few embodiments of the invention, it should be apparent to those 
skilled in the an that the foregoing is merely illustrative and not limiting, having been presented 
by way of example only. Numerous modifications and other embodiments are within the scope 
of one of ordinary skill in the art and are contemplated as falling within the scope of the 
invention as defined by the appended claims and equivalent thereto. 
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CLAIMS 

1 ; A compuier-implemenied process for executing encrypicd computer program logic while 
maintaining protection against copying of corresponding decrypted executable computer 
program logic, wherein the encrypted computer program logic is stored in association with first 
executable computer program logic, the process comprising the steps of: 

through an operating system of a computer, reading, loading and cxccutmg the first 
executable computer program logic as a first process having a protected memory area defined by 
the operating system; 

the first process decrypting the encrypted computer program logic into second executable 
computer program logic and storing the second executable computer program logic in the 
protected memory area; and 

the first process causing loading and execution of the decrypted second computer 
program logic in the protected memory area. 

2. The process of claim 1 , wherein the encrypted computer program logic and the first 
executable computer program logic are stored in a single data file accessible through the 
operating system. 

3 . The process of claim 1 , wherein the execution of the decrypted second computer program 
logic is performed as a second process having a second protected memor>' area defined by the 
operating system. 

4. A digital information product including a computer readable medium having digital 
information stored thereon, the digital information including computer program logic defining 
first executable computer program logic, wherein the first executable computer program logic 
when executed performs the following steps: 

storing the encrypted computer program logic in a data file accessible through an 
operating system of a computer, wherein the data file also includes first executable computer 
program logic: 

through the operating system, reading, loading and executing the first executable 
computer program logic from the data file as a first process having a protected memory area: 
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the first process decrypting the encrypted computer program logic into second executable 
computer program logic and storing the second executable computer program logic in the 
protected memory area; and 

the first process causing loading and execution of the decrypted second computer 
5 program logic in the protected memory area. 

5. A computer system comprising: 

a processor for executing computer program logic; 

a main memory operaiively connected to the processor for storing digital information 
10 including executable computer program logic at memory locations addressed by the processor: 
and 

an operating system defined by executable computer program logic stored in tlie memor>' 
and executed by the processor and having a cornmand which when executed by the processor 
defines means for creating a process in response to a request specifying a process identifier and a 
15 memory location in the main memory, wherein the process identifier indicates the process 
making the request and the memor>' location stores executable computer program logic which 
when executed defines the process. 

6. A computer system having an operating system, for decrypting digital information, 
20 comprising: 

means for storing the encrypted computer program logic in a data file accessible through 
the operating system, wherein the data file also includes first executable computer program logic; 

means, invokable through the operating system, for reading, loading and executing the 
first executable computer program logic from the data file as a first process having a protected 
25 memory area; 

the first process defining means for decrypting the encrypted computer program logic 
into second executable computer program logic and storing the second executable computer 
program logic in the protected memory area; and 

the first process defining means for causing loading and execution of the decr>'pted 
30 second computer program logic in the protected memor>' area. 
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7. The compuier system of claim 6, wherein ihe encrypted computer program logic and the 
first executable computer program logic are stored in a single data file accessible through the 
operating system. 

5 8. The computer system of claim 6, wherein the execution of the decrypted second computer 
program logic is performed as a second process having a second protected memory area defined 
by the operating system. 

9. A digital information product, including a compuier readable medium with computer readable 
10 information stored thereon, wherein the computer readable information comprises: 

a first portion of executable computer program logic; and 
a second portion of encrypted digital information; and 

wherein the first portion of executable program logic, when executed, defines means, 
operative in response to requests for digital information, for accessing the second portion of 
15 encrypted digital information, for decrypting the encrypted digital information, and for 
outputting the decrypted digital information. 

10. The digital information product of claim 9, wherein the encrypted digital information is 
encrypted executable computer program logic. 

20 

11. A computer program product including a self-decrypting encrypted executable computer 
program, comprising: 

a computer readable medium having computer program logic stored thereon, wherein the 
computer program logic defines: 
25 a first module, 

a second module, 

wherein the first module, when executed by a computer, defines means for loading the 
second module into memory of the computer, and 

a third module defining the encrypted executable compuier program. 
30 wherein the second module, when executed by a compuier. defines means for 

communicating with an operating system of the computer to receive requests for program code 
from the encrypted executable computer program from the third module, and for processing the 
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requests to access and decrypt the encrypted cxecutabk computer program and for providing the 
decrypted executable code from the third module to the operating system. 

1 2. A process for executing encrypted executable computer programs on a computer SN'stem 
5 having a processor. memor\' and operating system, comprising the steps of: 

receiving computer program logic having a first module defming a start up routine, a 
second module, and a Ihird module containing the encrypted executable computer program; 

executing the first module of the received computer program logic using the processor. 

wherein the step of executing causes the second module to be loaded into the memory ol" 
1 n the computer system, and 

generating requests from the operating system for data from the encrypted executable 
computer program which are received by the second module, and 

accessing and decrypting the encrypted executable computer program and returning the 
decrypted executable computer program to the operating system. 
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SELF-DECRYPTING DIGITAL INFORMATION SYSTEM AND METHOD 

FiplH nftho Invention 

The present invention is related to mechanisms for protecting digital information from 
being copied. In particular, the present invention is related to mechanisms which permit 
authorized execution of computer program code or access to other digital information which is 
encrypted or otherwise encoded. 

Background of the Invention 

A serious problem which faces the electronic publishing and software industries is the 
ease with which digital information can be copied without authorization from the publisher. 
Digital information also may be used or modified without authorization. For example, computer 
software may be reverse engineered or attacked by computer viruses. 

There are many mechanisms available which may be used to limit or prevent access to 
digital information. Such mechanisms often either restrict the ability of the user to make back-up 
copies or involve the use of special purpose hardware to limit access to the digital information. 
For example, some mechanisms restrict the use of digital information to a particular machine. 
See, for example, U.S. Patent 4,817,140. Other mechanisms require the digital information to be 
stored on a particular recording medium in order to be used. See, for example, U.S. Patent " 
5,412,71 8. Yet other mechanisms allow only a certain number of uses of the digital information. 
See for example, U.S. Patent 4,888,798. Many of these access control mechanisms cause 
distribution to be more costly. 

Several other patents describe a variety of systems for encryption, compression, 
licensing and royalty control and software distribution such as: U.S. Pat. No. 4.405,829, U.S. 
Pat. No. 4,864,616, U.S. Pat. No. 4,888,800, U.S. Pat. No. 4,999,806, U.S. Pat. No. 5,021,997, 
U.S. Patent No. 5,027,396, U.S. Pat. No. 5,033,084, U.S. Pat. No. 5,081.675, U.S. Pal. No. 
5,1 55,847, U.S. Pat. No. 5,166,886, U.S. Pat. No. 5,191,61 1, U.S. Pat. No. 5,220,606, U.S. Pat, 
No. 5,222,133, U.S. Pat. No. 5,272,755, U.S. Pat. No. 5,287,407, U.S. Pat. No. 5,313,521. U.S. 
Pat. No. 5,325,433, U.S. Pat. No. 5,327,563, U.S. Pat. No. 5,337,357, U.S. Pat. No. 5,351.293, 
U.S. Pat. No. 5,341,429, U.S. Pat. No. 5,351 .297, U.S. Pat. No. 5.361,359, U.S. Pat. No./ 
5.379,433, U.S. Pat. No. 5.392,351 , U.S. Pat. No. 5,394,469, U.S. Pat. No. 5.414.850, U.S. Pal. 
No. 5,473,687, U.S. Pat. No. 5.490.216, U.S. Pal. No. 5.497.423, U.S. Pat. No. 5,509,074, U.S. 
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Pat. No. 5„51 K123, U.S. Pai. No. 5,524,072, U.S. Pat. No. 5,532,920, U.S. Pat. No. 5,555.304. 
U.S. Pat. No. 5.557,346. U.S. Pat. No. 5,557,765, U.S. Pat. No. 5.592,549, U.S. Pat. No. 
5,615.264, U.S. Pal. No. 5,625,692, and U.S. Pat. No. 5,638,445. 

Computer programs or other digital information also may be encrypted in order to 
5 prevent an individual from making a useful copy of the information or from reverse engineering 
a program. Even with such encryption, however, a computer program must be decrypted in order 
for a computer to load and execute the program. Similarly, other digital information must be 
decrypted before it can be accessed and used. Generally, digital information is decrypted to disk, 
and not to main memory of the computer which is more protected by the operating system, 
} 0 because decryption to main memory results in a significant loss of memory resources. If the 
purpose for using encryption is to prevent users from copying the digital information, then 
decryption of the information to accessible memory for use defeats this purpose. 

One way to protect digital information using encryption has been made available by 
International Business Machines (IBM) and is called a "CRYPTOLOPE'' information container. 
1 5 This technology is believed to be related to U.S. Patent Nos. 5,563,946 and 5,598,470 (to Cooper 
et al.), and published European patent applications 0679977, 0679978, 0679979 and 0681233. 
The CRYPTOLOPE system requires a user to have a "helper application" and a key. The 
CRYPTOLOPE information container is generated by IBM. The content provider submits data 
to IBM, which in turn encrypts and packages the data in a CRYPTOLOPE information container. 
20 The helper application is a form of memory resident program, called a terminate and stay 
resident (TSR) program, which is a forni of input/output (1/0) device driver installed in the 
operating system and which monitors requests from the operating system for files on specified 
drives and directories. Because the TSR program must know the directory, and/or file name to 
be accessed, that information also is available to other programs. Other programs could use that 
25 information to manipulate the operation of the TSR program in order to have access to decr\pted 
contents of the information container. The encrypted information container includes an 
executable stub which is executed whenever the application is run without the installed TSR 
program or from a drive not monitored by the TSR program to prevent unpredictable activity 
from executing encrypted code. This stub may be used to install decr>'piion and cause the 
30 application be executed a second time, or to communicate with the TSR program to instruct the 
TSR program to monitor the drive. It may be preferable from the point of view of the conteni 
provider however to maintain an encryption process and keys independently of any third party. 
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Multimedia coment. such as a movie or hypenexi presentation also may be stored on a 
digital versatile disk (DVD), sometimes called a digital video disk, compact disk read-only 
memory (CD-ROM), rewriteable compact disks (CD-RW) or other medium in an encrypted 
digital format for use with special-purpose devices. For example, concern about illegal copying 

< of content from digital video disks or other digital media has resulted in a limited amount of 
content being available for such devices. This problem has caused representatives of both 
multimedia providers and digital video disk manufacturers to negotiate an agreement on an 
encryption formal for information stored on DVDs. This copy protection scheme is licensed 
through an organization called the CSS Interim Licensing organization. However, in this 

1 0 arrangement, the content provider is limited to using the agreed upon encryption format and a 
device manufacturer is limited to using a predetenmined decryption system. 

Encryption has also been used to protect and hide computer viruses. Such viruses are 
typically polymorphic, i.e.. they change every lime they infect a new program, and are encrypted. 
The virus includes a decr\'plion program that executes to decrypt the virus every time the 

] 5 infected program is run. Such viruses are described, for example, in "Computer Virus-Antivirus 
Coevolution^^ by Carey Nachenberg, r.f^mmunications of the ACM. Vol. 40, No. 1 , (Jan. 1 997), 
p. 46 et seq- Sucii viruses include decryption keys within them since, clearly, their execution is 
not carried out b\- the user and a user would not be asked for authorization keys to permit 
execution of the viruses. Additionally, such viruses are typically only executed once at the start 

20 of execution of an infected program and permanently return control to the infected program after 
execution. 

Summarv of the Invention 

Some of these problems with digital information protection systems may be overcome 
25 by providing a mechanism which allows a content provider to encr>'pt digital information 

without requiring either a hardware or platform manufacturer or a content consumer to provide 
support for the specific form of corresponding decryption. This mechanism can be provided in a 
manner which allows the digital information to be copied easily for back-up purposes and to be 
transferred easily for distribution, but which should not permit copying of the digital information 
30 in decrypted form. In panicular, the encrypted digital information is stored as an executable 
computer program which includes a decryption program that decr\'pts the encrypted information 
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to provide the desired digital information, upon successful completion of an authorization 
procedure by the user. 

In one embodiment, the decryption program is executed as a process within a given 
operating system and decrypts the digital information within the memory area assigned to thai 
; process. This memory area is protected by the operating system from copying or access by other 
processes. Even if access to the memory area could be obtained, for example through the 
operating system, when the digital information is a very large application program or a large data 
file, a copy of the entire decrypted digital information is not likely to exist in the memory area in 
complete form. 

1 0 By encrypting information in this manner, a platform provider merely provides a 

computer system with an operating system that has adequate security to define a protected 
memory area for a process and adequate functionality to execute a decryption program. The 
content provider in turn may use any desired encryption program. In addition, by having a 
process decrypt information within a protected memory area provided by the operating system, 
1 5 the decrypted information does not pass through any device driver, memory resident program or 
other known logical entity in the computer system whose behavior may be controlled to provide 
unauthorized access to the data. The ability to reverse engineer or attack a computer program 
with a computer virus also may be reduced. 

In another embodiment, the decryption program is part of a dynamically loaded device 
20 driver that responds to requests for data from the file containing the encrypted data. When the 
digital information product is first executed, this device driver is extracted from the file and is 
loaded into the operating system. The executed digital information product then informs the 
loaded device driver of the location of the hidden information in the file, any keys or other 
passwords, and the name of a phantom directory and file to be called that only the digital 
25 information product and the device driver know about. The name of this director>' may be 

generated randomly. Each segment of hidden information in the digital information product may 
be assigned its own unique file name in the phantom directory. The digital information product 
then makes a call to the operating system to execute one of the files in the phantom directors . 
The loaded driver traps these calls to the operating system, accesses the original file, decr>pts the 
30 desired information and outputs the desired information to the operating system. 

In combination with other mechanisms that track distribution, enforce royalty payments 
and control access to decryption keys, the present invention provides an improved method for 
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identifying and delecting sources of unauthorized copies. Suitable authorization procedures also 
enable the digital information to be distributed for a limited number of uses and/or users, thus 
enabling per-use fees to be charged for the digital information. 

Accordingly, one aspect of the invention is a digital information product including a 
5 computer-readable medium with digital information stored thereon. The digital information 
includes computer program logic having a first portion of executable computer program logic 
and a second portion of digital information. The first portion of executable program logic, when 
executed, defines a mechanism for responding to requests for digital information from an 
operating system of a computer. This mechanism, when used to access the second portion of the 
10 encrypted digital information, decrypts the encrypted digital information, and provides the 
encrypted digital information to the operating system. 

In the foregoing aspect of the invention, the digital information may be executable 
computer program logic. Hence, one aspect of the invention is a computer program product, . 
including a computer readable medium with computer program logic stored thereon. The 
1 5 computer program logic includes a first portion of executable computer program logic and a 
second portion of encrypted computer program logic. The first portion of executable computer 
program logic, when executed, defines a mechanism for responding to requests for computer 
program logic from an operating system of a computer. This mechanism accesses the second 
portion of encrypted computer program logic, decrypts the encrypted computer program logic, 
20 and provides the decrypted computer program logic to the operating system. 

Another aspect of the present invention is a computer program product, a computer 
system and a process which produce a computer program or digital information product in • 
accordance with other aspects of the invention, using executable program code for the first and 
second portions of the desired computer program product. 
25 Another aspect of the present invention is a computer program product including a self- 

decr}'pting encrypted executable computer program. The product includes a computer readable 
medium having computer program logic stored thereon. The computer program logic defines 
first, second and third modules, wherein the third module defines the encrypted executable 
computer program. The first module, when executed by a computer, defines a mechanism for 
30 loading the second module into memory of the computer. The second module, when executed by 
a computer, defines a mechanism for communicating with an operating system of the computer 
10 receive requests for program code from the encr>'pted executable computer program from the 
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third module, and for processing the requests lo access and decr>'pi the encrypted executable 
computer program and for providing the decrypted executable code from the third module to the 
operating system. 

Another aspect of the invention is a process for executing encrypted executable 
5 computer programs on a computer system having a processor, memory and operating system. 
The process involves receiving computer program logic having a first module defining a stan up 
routine, a second module, and a third module containing the encrypted executable computer 
program. The first module of the received computer program logic is executed using the 
processor. When the first module is executed, the second module is caused to be loaded into the 
10 memor>' of the computer system. Requests are generated from the operating system for data 
from the encrypted executable computer program and are received by the second module. The 
second module accesses and decrypts the encrypted executable computer program in response to 
these requests and returns the decrypted executable computer program to the operating system. 
These and other aspects, advantages and features of the present invention and its . 
15 embodiments will be more apparent given the following deuiled description. 

Rricf Descrintion of the Drawing 

In the drawing. 

Fig. 1 is a block diagram of a typical computer system with which the present invention 
20 may be implemented; 

Fig. 2 is a block diagram of a memory system in the computer system of Fig. 1; 
Fig. 3 is a diagram of a computer program or digital information product which may be 
recorded on a computer readable and writable medium, such as a magnetic disc; 

Fig. 4 is a flowchart describing how the computer program or digital information 
25 product of Fig. 3 is used; 

Fig. 5 is a flowchart describing operation of an example unwrap procedure as shown in 
Fig. 3 in one embodiment of the invention; 

Fig. 6 is a flowchart describing operation of an example device driver as shown in Fig. 
3 in one embodiment of the invention; 
30 Fig. 7 is a block diagram of a computer system in the process of executing a computer 

program product in accordance with one embodiment of the invention; 
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Fig. 8 is a flowchart describing operation of an example unwrap procedure in another 
embodiment of the invention; and 

Fig. 9 is a flowchart describing how a computer program product such as shown in Fig. 
3 is constructed. 

5 

Detailed Description 

The present invention will be more completely understood through the following 
detailed description which should be read in conjunction with the attached drawing in which 
similar reference numbers indicate similar structures. 
10 Embodiments of the present invention may be implemented using a general purpose 

digital computer or may be implemented for use with a digital computer or digital processing 
circuit. A typical computer system 20 is shown in Fig. 1, and includes a processor 22 comiected 
to a memory system 24 via an interconnection mechanism 26. An input device 28 also is 
connected to the processor and memory system via the interconnection mechanism, as is an 
! 5 output device 30. The interconnection mechanism 26 is typically a combination of one or more 
buses and one or more switches. The output device 30 may be a display and the input device 
may be a keyboard and/or a mouse or other cursor control device. 

It should be understood that one or more output devices 30 may be connected to the 
computer system. Example output devices include a cathode ray tube (CRT) display, liquid 
20 crystal display (LCD), television signal encoder for connection to a television or video tape 

recorder, printers, communication devices, such as a modem, and audio output. It also should be 
understood that one or more input devices 28 may be connected to the computer system. 
Example input devices include a keyboard, keypad, trackball, mouse, pen and tablet, 
communication device, audio or video input and scanner. It should be understood that the 
25 invention is not limited to the particular input or output devices used in combination with the 
computer system or to those described herein. 

The computer system 20 may be a general purpose computer system, which is 
programmable using a high level computer programming language, such as "C-^," "Pascal" 
"VisualBasic.'' The computer system also may be implemented using specially programmed, 
30 special purpose hardware. In a general purpose computer system, the processor is typically a 
commercially available processor, such as the Pentium processor from Intel Corporation. Many 
other processors are also available. Such a processor executes a program caHed an operating 
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system, such as Windows 95 or Windows NT 4.0, both available from Microsoft Corporation, 
which controls the execution of other computer programs and provides scheduling, debugging, 
input output control, accounting compilation, storage assignment, data management and memory 
management, and communication control and related services. Other examples of operating 
systems include: MacOS System 7 from Apple Computer. OS/2 from IBM. VMS from Dieital 
Equipment Corporation, MS-DOS from Microsoft Corporation, UNIX from ATiS:T. and IRIX 
from Silicon Graphics, Inc. 

The computer system 20 also may be a special purpose computer system such as a 
digital versatile disk or digital video disk (DVD) player. In a DVD player, there is typically a 
decoder controlled by some general processor which decodes an incoming stream of data from a 
DVD. In some instances, the DVD player includes a highly integrated DVD decoder engine. 
Such devices generally have a simple operating system which may be modified to include the 
capabilities described and used herein in connection with the typical operating systems in a 
general purpose computer. In panicular, some operating systems are designed to be small 
15 enough for installation in an embedded system such as a DVD player, including the WindowsCE 
operating system from Microsoft Corporation and the JavaOS operating system from SunSoft 
Corporation. The operating system allows a content provider to provide its own programs that 
define some of the content, which is particularly useful for interactive multimedia. This 
capability also can be used to provide encryption and decryption, in accordance with the 
20 invention. 

The processor and operating system define a computer platform for which application 
programs in a programming language such as an assembly language or a high level programming 
language are written. It should be understood that the invention is not limited to a particular 
computer platfonn, operating system, processor, or programming language. Additionally, the 

25 computer system 20 may be a multi-processor computer system or may include multiple 
computers connected over a computer network. 

An example memory system 24 will now be described in more detail in connection with 
Fig. 2. A memory system typically includes a computer readable and writable non-volatile 
recording medium 40, of which a magnetic disk, a flash memory, rewTiteable compact disk (CD- 

30 RW) and tape are examples. The recording medium 40 also may be a read only medium such as 
a compact disc-read only memory (CD-ROM) or DVD. A magnetic disk may be removable, 
such as a "floppy disk" or ''optical disk " and/or permanent, such as a "hard drive." The disk. 
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which IS shown in Fig. 2, has a number of tracks, as indicated at 42, in which signals are stored, 
in binary fonn, i.e:, a form interpreted as a sequence of I's and 0"s, as shown at 44. Such signals 
may define an application program to be executed by the microprocessor, or information stored 
on the disk to be processed by the application program. Typically, in the operation of a general 
5 purpose computer, the processor 22 causes data to be read from the non-volatile recording 
medium 40 into an integrated circuit memory element 46, which is typically a volatile random 
access memory, such as a dynamic random access memory (DRAM) or stauc random access 
memory (SRAM). The integrated circuit memory element 46 allows for faster access to the 
information by the processor than disk 40, and is typically called the system or host memor> . 
10 The processor generally causes the data to be manipulated within the integrated circuit memory 
46 and may copy the data to the disk 40, if modified, when processing is completed. A variety of 
mechanisms are known for managing data movemem between the disk 40 and the integrated 
circuit memory 46, and the invention is not limited thereto. It should also be understood that the 
invention is not limited to a particular memory system. 
1 5 The file system of a computer generally is the mechanism by which an operating system 

manages manipulation of data between primary and secondary storage, using files. A file is a 
named logical construct which is defined and implemented by the operating system to map the 
name and a sequence of logical records of data to physical storage media. An operating system 
may specifically support various record types or may leave them undefined to be interpreted or 
20 controlled by application programs. A file is referred to by its name by application programs and 
is accessed through the operating system using commands defined by the operating system. An 
operating system provides basic file operations provided by for creating a file, opening a file, 
writing a file, reading a file and closing a file. 

In order to create a file, the operating system first identifies space in the storage media 
25 which is controlled by the file system. An entry for the new file is then made in a director)- 
which includes entries indicating the names of the available files and their locations in the file 
system. Creation of a file may include allocating certain available space to the file. Opening a 
file returns a handle to the application program which it uses to access the file. Closing a file 
invalidates the handle. 

30 In order to write data to a file, an application program issues a command to the 

operating system which specifies both an indicator of the file, such as a file name, handle or 
other descriptor, and the infomiation to be wrinen to the file. Given the indicator of the file, the 
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operating system searches the directory to find the location of the file. The directory emr>^ stores 
a pointer, called the write pointer, to the current end of the file. Using this pointer, the physical 
location of the next available block of storage is computed and the information is written to that 
block. The write pointer is updated in the directory to indicate the new end of the file. 

5 In order to read data from a file, an application program issues a command to the 

operating system specifying the indicator of the file and the memory locations assigned to the 
application where the next block of data should be placed. The operating system searches its 
director\' for the associated entry given the indicator of the file. The directory may provide a 
pointer to a next block of data to be read, or the application may program or specify some offset 

10 from the beginning of the file to be used. 

A primary advantage of using a file system is that, for an application program, tlie file is 
a logical construct which can be created, opened, written to, read from and closed without any 
concern for the physical storage used by the operating system. 

The operating system also allows for the definition of another logical construct called a 

15 process. A process is a program in execution. Each process, depending on the operating system, 
generally has a process identifier and is represented in an operating system by a data structure 
which includes information associated with the process, such as the state of the process, a 
program counter indicating the address of the next instruction to be executed for the process, 
other registers used by process and memory management information including base and bounds 

20 registers. Other information also may be provided. The base and bounds registers specified for a 
process contain values representing the largest and smallest addresses that can be generated and 
accessed by an individual program. Where an operating system is the sole entity able to modify 
these memory management registers, adequate protection from access to the memory locations of 
one process from another process is provided. As a result, this memorv' management information 

25 is used by the operating system to provide a protected memory area for the process. A process 
generally uses the file system of the operating system to access files. 

The present invention involves storing encrypted digital information, such an audio, 
video, text or an executable computer program, on a computer readable medium such that it can 
be copied easily for back-up purposes and transferred easily for distribution, but also such that it 

30 cannot be copied readily in decrypted form during use. In particular, the digital information is 
stored as a computer program that decrypts itself while it is used to provide the digital 
information, e.g.. to provide executable operation code to the operating system of a computer, as 
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the digital informaiion is needed. Any kind of encryption or decryption may be used and also 
may include authorization mechanisms and data compression and decompression. In one 
embodiment of the present invention, decrypted digital information exists only in memor>' 
accessible to the operating system and processes authorized by the operating system. When the 
5 digital information is a large application program, a copy of the entire decrypted application 
program is not likely to exist in the main memory at any given time, further reducing the 
likelihood that a useful copy of decrypted code could be made. The decryption operation also is 
performed only if some predetermined authorization procedure is completed successfully. 
One embodiment of the invention, in which the decryption program is a form of 
10 dynamically loaded device driver, will first be described. Fig. 3 illustrates the structure of digital 
information as stored in accordance with one embodiment of the present invention, which may 
be stored on a computer readable medium such as a magnetic disc or compact disc read only 
memory (CD-ROM) to form a computer program product. The digital information includes a 
first portion 50, herein called an unwrap procedure or application, which is generally 
1 5 unencrypted executable program code. The purpose of the unwrap procedure is to identify the 
locations of the other portions of the digital information, and may perform other operations such 
as verification. In particular, the unwrap procedure identifies and extracts a program which will 
communicate with the operating system, herein called a virtual device driver 52. The unwrap 
procedure may include decryption and decompression procedures to enable it to 
20 decrypt/decompress the driver, and/or other content of this file. The program 52 need not be a 
device driver. The virtual device driver 52 typically follows the unwrap procedure 50 in the file 
container, the digital information. The virtual device driven when executed, decrypts and 
decodes the desired digital information such as an executable computer program code from 
hidden information 54, which may be either encrypted and/or encoded (compressed). It is the 
25 decrypted hidden information which is the desired digital information to be accessed. This 
hidden information may be any kind of digital data, such as audio, video, text, and computer 
program code including linked libraries or other device drivers. 

• In this embodiment of the computer program product, labels delineate the boundaries 
between the device driver and the hidden files. These labels may or may not be encrypted. A 
30 first label 56 indicates the beginning of the code for the vinual device driver 52. A second label 
58 indicates the end of the virtual device driver code. Anotlier label 60 indicates tlie beginning 
of the hidden information and a label 62 indicates the end of that application. There may be one 
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or more blocks of such hidden information, each of which can be given a different name. It may 
be advantageous to use the name of the block of information in its begin and end tags. This 
computer program product thus contains and is both executable computer program code and one 
or more blocks of digital information. A table of locations specifying the location of each 
5 portion of the product could be used instead of labels. Such a table could be stored in a 
predetermined location and also may be encrypted. 

The overall process performed using this computer program product in one embodiment 
of the invention will now be described in connection with Fig. 4. This embodiment may be 
implemented for use uith the Windows95 operating system and is described in more detail in 
10 connection with Figs. 5-7. An embodiment which may be implemented for use on the 

WindowsNT 4.0 operating system is described in more detail below in connection with Fig. 8. 
In both of these described embodiments, the digital information is an executable computer 
program which is read by the operating system as data from this file and is executed. The same 
principle of operation would apply if the data were merely audio, video, text or other information 
15 to be conveyed by a user. In the embodiment of Fig. 4, the computer program is first loaded 
into memory in step 70, and the unwrap procedure 50 is executed by the operating system, as any 
typical executable computer program is executed. The unv^p procedure may perform 
authorization, for example by checking for a required password or authentication code, and may 
receive any data needed for decryption or decompression, for example keys or passwords, in step 
20 72. Suitable authorization procedures may provide the ability to distribute software for single 
use. The unwrap procedure locates the virtual device driver 52 within the computer program in 
step 74, and then locates the hidden ^plication in step 76. The virtual device driver 52 is then 
extracted by the unwrap procedure from the computer program, copied to another memory 
location and loaded for use by the operating system in step 78. An advantage of an operating 
25 system like Windows95 is that it allows such device drivers to be loaded dynamically without 
restarting the computer. 

The executed unwrap procedure 50, in step 80, informs the loaded vinual device driver 
52 of the location of the hidden information in the file, any keys or other passwords, and a name 
of a phantom directory and file to be called that only the unwrap procedure and the vinual device 
30 driver know about. The name of this phantom directory may be generated randomly. Eacli 
segment infomiation hidden in the digital information product may be assigned its owti unique 
file name in the phantom director\'. 
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Afier the loaded virtual device driver 52 receives all communications from the unwrap 
procedure, it opens the original application file for read only access in step 82. The unwrap 
procedure then makes a call to the operating system in step 84 to execute the file in the phantom 
directoPr' for which the name was transmitted to the loaded vinual device driver. One function of 

5 the loaded virtual device driver 52 is to trap all calls from the operating system to access files in 
step 86. Any calls made by the operating system to access files in the phantom directory are 
processed by the virtual device driver, whereas calls to access files in other directories are 
allowed to proceed to their original destination. In response to each call from the operatmg 
system, the virtual device driver obtains the bytes of data requested by the operating system from 

10 the original computer program file in step 88. These bytes of data are then decrypted or 

decompressed in step 90 and returned to the operating system. When processing is complete, the 
phantom application is unloaded from the operating system in step 92, and may be deleted from 
the memory. 

A more detailed description of the process of Fig. 4 will now be described in connection 
15 with Figs. 5-7. Fig. 5 is a flowchart describing the operation of one embodiment of the unwrap 
procedure in more detail. The first step performed by this procedure is identifying the operating 
system being used, in step 100. This step is useful because different methods may be used with 
different operating systems. All code that may be used to run in various operating systems may 
be placed in this unwrap procedure. This procedure also may contain the 
20 decompression/decryption code, for example or any other computer program code to be 
executed. 

The executed application then opens the original executable file as a data file and 
searches for the begin and end tags of the device driver and hidden files in step 1 02. The device 
driver code is copied into memory and loaded into the operating system in step 1 04. The unwrap 

25 procedure then informs the device driver of the name of the original application file, offsets of 
the hidden files and the name of a phantom directory, which is typically randomly generated 
(step 106). This communication may be performed using a "DevicelOControl" function call in 
the Windows95 operating system. The unwrap procedure then makes a call to the operating 
system to execute the hidden file in the phantom directory, in step 108. 

30 The operation of one embodiment of a device driver will now be described in 

connection with Fig. 6. After the device driver is loaded into the operating system, ii hooks into 
a position between the operating system and a file system driver (FSD). in step 1 10. to intercept 
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calls made by the operaiing system to the FSD for data from files in the phantom director>\ The 
FSD is the code within the operating system that performs physical reading and writing of data to 
disk drives. The operating system makes requests to the FSD for data from files in directories on 
the disk drives. The driver then receives information fi-om the unwrap procedure including the 

5 name of the original file, the location of hidden files within the original file, and the name of the 
phantom director)' created by the unwrap procedure (step 1 12). The device driver opens the 
original file as a read only data file. The device driver now traps calls, in step 1 14, made from 
the operating system for files in the phantom directory. Calls to other directories are ignored and 
passed on to the original destination. The device driver then reads the data from the original data 

10 file, decrypts and decompresses it, and returns the decrypted/decompressed data to the operating 
system in step 116. 

For example, if the offset for the hidden application in the original data file is 266,270 
bytes and the operating system asks for 64 bytes starting at offset 0 of the hidden application in 
the phantom directory, the device driver reads 64 bytes from the original file starting at offset 
15 266,270, decrypts/decompresses those 64 bytes, and returns the first 64 decrypted/decompressed 
bytes back to the operating system. From the point of view of the operating system, the 64 bytes 
appear to have come from the file in the phantom directory. Steps 114 and 1 16 are performed on 
demand in response to the operating system. 

A block diagram of the computer system in this embodiment, with a device driver 
20 loaded and in operation, will now be described in more detail in connection with Fig. 7. Fig. 7 
illustrates the operating system 120, the loaded device driver 122, a file system driver 124, the 
original executable file 126 as it may appear on disk and the unwrap procedure 128. The 
executable file may in fact be on a remote computer and accessed through a network by the 
device driver. The unwrap procedure causes the operating system to begin execution of the 
25 hidden file by issuing an instruction to execute the file in the phantom directory, as indicated at 
1 30. This command is issued after the device driver 122 is informed of the file name of the 
original executable file 126, offsets of the hidden files within that file and the name of the 
phantom directory, as indicated at 132. The operating system then starts making calls to the 
phantom directory as indicated at 134. The device driver 122 traps these calls and turns them 
30 into requests 1 36 to the file system driver to access the original executable file 126. Such 

requests actually are made to the operating system 120, through the device driver 122 lo the file 
system driver 124. The file system driver 124 returns encrypted code 1 38 to the device driver 
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122. The encrypted code 138 actually passes back through the device driver 122 to the operating 
system 120 v^hich in turn provides the encrypted code 138 to the device driver 122 as the reply lo 
the request 136 for the original file. The device driver 122 then decrypts the code to provide 
decr>'pied code 140 to the operating system 120. 

5 Another embodiment of the invention will now be described in connection with Fig. 8. 

This embodiment may be implemented using the WindowsNT 4.0 operating system, for 
example. In this embodiment, the device driver portion 52 of the computer program product is 
not used. The unwrap procedure for this embodiment begins by identifying the operating system 
being used similar, which is step 1 00 in Fig. 5. If the operating system is Window^s NT 4.0, for 

1 0 example, a different unwrap procedure for this embodiment is performed. Before describing this 
unwrap procedure, a brief description of some of the available operating system commands will 
be provided. 

Currently, under all versions of the Window operating system or operating environment 
from Microsoft Corporation (such as Windows 3.1, Windows 95 and Windows NT 3.51 and 4.0) 

15 all executable files (.exc) or dynamic link library (.dll and .ocx) files, which are executable files 
with different header and loading requirements than .exe files, that are loaded into memory by 
the operating system must reside as a file either locally, e.g., on a disk drive or remotely, e.g., 
over a network or communications port. All further references herein to loading an executable 
will be using the Win32 function calls used in Windows 95 and NT 3.51 and 4.0 operating 

20 systems. The CrcateProccss() function which loads files with an .exe extension takes ten 
parameters: 

BOOL CreatcProcess{// Prototype from Microsoft Visual C+ + Help Documemaiion 
LPCTSTR IpApplicationName, II pointer lo name of executable module 

25 . LPTSTR IpComniandUne, H pointer lo command line string 

LPSECURITY_ATTRIBUTES IpFrocessArtribmes, II pointer to process security attributes 
LPSECURITY_ATTRIBUTES IpThreadAnribmes, // pointer to thread security attributes 
BOOL bInheriiHandles, II handle inheritance nag 

DWORD dwCreaiionFiags, 1 1 creation flags 

30 LPVOID IpEnvironmenu ^ Poin^er to new environment block 

LPCTSTR IpCurreniDirectory, II pointer to current director)' name 

LPSTARTUPINFO IpStanuplnfo, II pointer to STARTUPINFO 

LPPROCESS_INFORMATION IpProcessinformaiion II pointer to PROCESS^lNFORMATiON 

); 
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10 



15 



20 



25 



Three of these parameters are pointers to strings that conuin an apphcation file name, command 
line parameters, and the current director>'. The other parameters are security, environmental, and 
process information. The LoadLibraryO function takes one parameter that is a pointer to a string 
that contains the application file name: 

fflNSTANCE LoadLibrary{// Prototype from Microsoft Visual C+ + Help Documentaiion 
LPCTSTR IpLibFileName // address of filename of executable module 
); 

The LoadLibraryExO function takes three parameters the first being the same as LoadLibraryQ. 
the second paranieier must be null, and the third tells the operating system whether to load the 
file as an executable or as a data file in order to retrieve resources such as icons or string table 
data from it and not load it as an executable: 

HINSTANCE LoadLibraryEx(// Prototype from Microsoft Visual C+ + Help Documentation 
LPCTSTO IpLibFileName, // points to name of executable module 
HANDLE hfile, // reserved, must be NULL 

DWORD dwFlags II entry-point execution flag 



The CreateFileO function is used to create and open files and to load files such as device drivers. 
This function also requires a pointer to a string that contains the name of a physical file: 

HANDLE CreateFile(// Prototype from Microsoft Visual C + + Help Documentation 



LPCTSTR IpFileName, 
DWORD dwDesiredAccess, 



II pointer to name of the file 
// access (read-write) mode 



DWORD dwShareMode, 



II share mode 



LPSECURITY_ATTRIBIJTES IpSecuriiyAiiributes, 
DWORD dwCreationDistribunon, 



II pointer to security descriptor 



// how to create 



DWORD dy^FlagsAndAttributes, 
HANDLE hTempLmeFile 



II file attributes 



// handle to file with attributes to copy 
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There are other functions such as MapViewOfFile() and MapViewOfFileExO that map areas of 
memory to an already opened physical file through a handle to that file. They have the following 
parameters: 

LPVOID MapViewOrFile(// Proiorype from Microsoft Visual C + + Help Documeniation 



HANDLE hFileMappingObjecu 
DWORD dwDesiredAccess, 
DWORD dwFileOffsetHigh, 
DWORD dwFileOffsetLow, 
DWORD dwNumberOfBytesToMap 

); 



// file-mapping object to map inio address space 
// access mode 

// high-order 32 bits of file offset 
// low-order 32 bits of file offset 
// number of bytes to map 



LPVOID MapViewOfFileEx(// Prototype from Microsoft Visual C + + Help Documemation 



20 



HANDLE hFileMappingObjea, 
DWORD dwDesiredAccess, 
DWORD dwFileOffsetHigh, 
DWORD dwFileOffsetLow, 
DWORD dwNumberOfBytesToMap, 
LPVOID IpBaseAddress 
); 



// fiie-mapping object to map into address space 
// access mode 

// high-order 32 bits of file offset 

// low-order 32 bits of file offset 

// number of bytes to map 

// suggested starting address for mapped view 



25 



30 



All of the foregoing functions directly use a pointer to a string that is a physical file. The only 
file functions that do not directly use a physical filename are functions like CreateNamedPipeQ, 
which has the following parameters: 
HANDLE CreateNainedPipe(// Prototype from Microsoft Visual C+ + Help Documemation 



LPCTSTR IpName, 
DWORD dwOpenMode, 
DWORD dwPipeMode, 
DWORD nMoxlnsiances, 
DWORD nOuiBufferSize, 
DWORD nInBufferSize, 
DWORD nDefauliTimeOuu 

LPSECURITV^ATTRIBUTES IpSecuriryAnributes 
); 



// pointer to pipe name 

// pipe open mode 

// pipe-specific modes 

// maximum number of instances 

// output buffer size, in bytes 

// input buffer size, in bytes 

// time-out time, in milliseconds 

// pointer to security attributes structure 



35 
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The siring to which CreateNamedPipe() poims using the first parameter is a string that both an 
existing executable and the operating system know about and does not exist physically. 
Unfortunately both of the executables that "know" this private name could only be loaded using 
one of the other procedures that required a physical file. Currently it is not possible to load an 

5 executable using a "named pipe" name. Both of or any executables that use the name of the 
"named pipe" already must have been loaded into memory. 

All of the foregoing functions require a physical file because all of them use "file 
mapping" processes. File mapping allows large executable files to appear to be loaded rapidly 
since they are rarely completely loaded into memory but rather are mapped into memor\'. The 

10 detriment to this mapping capability is that executable code must remain in physical memorv' in a 
file in unencr>'pted form in order to be loaded, unless there is a middle layer or file system driver 
that the operating system uses as a physical layer and that decrypts the executable code to tlie 
operating system on demand. The potential weakness here is that another file system driver can 
hook into the operating system to monitor traffic between the operating system and all file 

15 system drivers and capture decrypted executable code passing from the file system driver to the 
operating system. Some operating systems allow such monitoring more than others. Many anti- 
viral software packages use this technique to prevent computer virus attacks. 

One method of loading and executing encrypted executable computer program code is to 
use a stub executable having two parts. The first part is the normal from end loader code that all 

20 executables have. In addition, the first part would perform any authorization which may include 
receiving a password from the user, then allocate enough memory to hold hidden encrypted code 
when it is decrypted, either in its entirety or a portion of it, copy the encrypted code into that area 
of protected (and preferably locked so no disk swapping occurs) memory, decrypt it once it is in 
memory and only in memory, and then have the operating system load the code only from 

25 memory therefore bypassing any file system drivers or TSRs so they have access to only 
encrypted code. 

Some of the file functions listed above and similar functions on other operating systems 
could be modified easily by a programmer having access to source code for those operating 
systems, or a new operating system may be made to provide functions which allow direct loading 
30 of executable code from memory rather than physical files. For example, in the Win32 

commands, a command similar to CreateProcess() command could be provided. The command 
should have a few extra parameters including the process identifier of the process that contains 
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the now decrypted executable code, the memory address of the start of the decrypted code, and 
the size of the decrypted code. The command could also contain a parameter specifying a "cali 
back" function within the first process that would provide decrypted code on demand directly to 
the operating system through a protected buffer, therefore allowing only a portion of the 
encrypted code to be decrypted at any one time instead of in its entirety, for better protection and 
less memory use. The second parameter of the LoadLibraryEx() command that now needs to be 
NULL could be expanded to hold a structure that contained the same information. Both of these 
and other similar functions could be changed or created to allow loading executable code either 
as an .exe, .dll, or other extensions or identifiers, such as by using a "named pipe" name that onh' 
the operating system and process that holds decrypted code know about and having the operating 
system load from the named pipe. 

Alternatively, without having such additional capabilities in the operating system, an 
application program can be divided into two parts. The first part is code that is common to alU 
applications such as code for allocating memory off the heap and code that provides some 
interaction with the user. This kind of code is generally not code that the content provider is . 
concerned about copying. The second pan is the code that the content provider believes is 
valuable. Typically this valuable code is a business logic code or what would be considered a 
middle tier of a three-tier environment, A content provider would like to protect this second part 
of the code, at least much more that the first part of the code. The content provider would place 
all of the important code to be protected inside a dynamic link library and the code that is not that 
important would reside in the front end "stub" executable. Both of these would be combined into 
another executable containing the .dll in encrypted form only, along with any other files, data, 
information, and/or tables for holding, for example, hardware identifiers. This other executable 
is the final digital information product. 

The first part of the digital information product, i.e., the executable stub, would load and 
execute normally like any other application. It then would perform any authorization procedures. 
Once the proper authorization or password was completed successfully, an unwrap procedure 
would be performed as will now be described in connection with Fig. 8. it would then allocate 
enough protected memory using a fianction like VirtualAlloc() as shown in step 1 50: 

DWORD nFileSize = 0; 
DWORD nPhantomPileSize = 0; 
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DWORD exeOffset = 0; 

DWORD nPreferredLoadAddress = GetPreCompiledLoadAddress(); 
CSiring cCommaiidFile = Un\vrapGetNTCommandFile(); 
exeOffsel = UnwrapGetDllOffset(cCommandFile); 
5 nFileSize = Un\vrapGetDllSize(cConmandFi!e); 

nPhaniomFileSize = nFileSize + 0x3000; // add any needed extra space 
// Increase buffer size to account for page size (currently Intel page size). 
DWORD nPageSize = GetPageSizeQ; 

nPhantomFileSize += (nPageSize -(nPhantomFileSize % nPageSize)); 
10 // Allocate the memory to hold the decrypted executable. 

LPVOID IpvBlock = VirtualAlloc((LPVOID) nPreferredLoadAddress, 
nPhantomFileSize, 

MEM_RESERVE | MEM_COMMIT, PAGE_RE AD WRITE): 

1 5 This function can request a particular address space. Preferably, this address space is the 
preferred load address space to which the .dll was linked in order to minimize any needed 
relocation and fix up code. The stub executable may lock that area of memory in step 152. for 
example by using VirtualLock() to prevent any memory writes to a swap file, depending on the 
operating system, as shown below: 

20 

BOOL bVLock = VirtualLock((LPVOID) nPreferredLoadAddress, nPhantomFileSize); 

The memory area still should be secure even without this preventive step since the Windows 95 
and NT operating systems do not allow any user access to swap files. ^ 

25 

The encrypted code is then copied from the digital information product into the allocated 
protected memory in step 1 54, for example by using the following command: 

UnwrapCopyHiddenExeToMem(cCommandFile, exeOffset, nFileSize, (char *) IpvBlock); 

30 

Once in memory, the stub would then decr\'pi the code to that same portion of memory in step 
1 56, for example by using the following commands; 
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CvvTapDecryptSeed(cPassword.GeiBuffer(0),cPassword.GeiUngth()); 
CwrapDecrypK (unsigned char *) IpvBlock, 0, nFileSize); 

Any "fix up and relocation" type services would then be performed in step 158, for example by 
5 using the following command: 

UnwrapFixUpAndRelocateDll(lpvBlock); 

Possibly, the memor>' protection may be changed to execute only in step 160. for example by 
1 0 using the VirtualProiect() command as follows; 

DWORD IpflOldProtect; // variable to get old protection 
BOOL bVProtect = VirtualProtect((LPVOID) nPreferredLoadAddress, 

nPhantomFileSize, 

J 3 PAGE^EXECUTE, 

&lpfl01dProtect); 

Function calls then can be made into that area of memory that now contains the decrypted code: 
20 UnwrapDoDllAlgorithmsO; 

Some of the "fix up" operations to be perfomied above include placing the addresses of external 
or siub-exe functions into the address place holders of the decrypted .dll or internal code, by 
using commands similar to the following: 

25 

WriteAddress((char*) 0x0a406104, (DWORD) &CallBackFunctionl); 
WriteAddress((char*) 0x0a406100, (DWORD) &CallBackFunction2); 

For instance a wrapper function could be created in the outer stub.exe that received a size 
30 parameter, allocated that amount of memory off of the heap, and passed back the starting address 
of that block of memory. Another example would be to have encrypted algorithms within the 
hidden. encr>pted .dll which would be called at run time from the front end stub once decrypted 
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within protected memor>'. The dynamic link library would be compiled and linked to expect a 
pointer to a function that look that parameter and/or returned a value by including prototypes in 
the header file as follows: 



5 void (*lpCallBackFuncl)(); 

void (♦lpCallBackFunc2)(unsigned long); 

Function calls to "external" functions also could be added as follows: 

10 (*ipCallBackFuncl)(); 
unsigned long z = x * x; 
(*lpCallBackFunc2)(z); 

At run time the "fix up" code would lake the run time address of that "wrapper function" and 
1 5 place it into the pointer address waihin ihe .dll block of code as follows: 

WriteAddress((char*) 0x0a4061 04, (DWORD) &CallBackFunctionl ); 
Write Address((char*) 0x0a406100, (DWORD) &CallBackFunction2); 

20 This information is readily available using the .cod output files from the compiler, an example of 
which follows: 

_TestSum PROC NEAR ; COMDAT 

; Line 8 

25 00000 56 push esi 

; Line 23 
00001 ff 15 00 00 00 

00 call DWORD PTRJpCallBackFuncl 

; Line 24 

30 00007 8b 44 24 08 mov eax, DWORD PTR^aS[esp] 

0000b 50 push eax 

0000c e8 00 00 00 00 call TestSquare 
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30 



0001 ] 


83 c4 04 


add 


esp, 4 


00014 


8b fO 


mov 


esi, eax 


; Line 25 








00016 


8b 44 24 Oc 


mov 


eax, DWORD PTR_b$(esp] 


0001a 


50 


push 


eax 


0001b 


e8 00 00 00 00 call 


_TestSquare 


00020 


83 c4 04 


add 


esp, 4 


00023 


03 c6 


add 


eax, esi 


: Line 28 








00025 


5e 


pop 


esi 


00026 


c3 


ret 


0 


_TestSum ENDP 






TEXT 


ENDS 







; COMDAT_TestSquare 
_TEXT SEGMENT 
_x$ = 8 

_TestSquare PROC NEAR 
; Line 30 

56 push esi 



COMDAT 



00000 
; Line 32 

00001 

00005 
; Line 34 

00008 

00009 

00 

OOOOf 83 c4 04 add 
00012 8b c6 
; Line 36 

00014 5e 

00015 c3 
_TesiSquare ENDP 



8b 74 24 08 mov esi, DWORD PTR _x$[esp] 

Of af f6 imul esi, esi 

56 push esi 

ff 15 00 00 00 

call DWORD PTR _lpCallBackFunc2 
esp, 4 

mov eax, esi 



pop 
rei 



esi 

0 
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Such information also is available from .map output files from the linker where the T' between 
the address (i.e., 0a406100) and the object file (i.e. Algorithms.obj) means it is a "flat" address 
(i.e.. hard coded by the linker) and the lack of an "f means that it is an address pointer to be 
supplied at run time (load time) where the address that is contained in that address location is 
5 used and not the actual address location (i.e., the address that is contained at address location 
0a4061 00 and not 0a4061 00 itself): 



10 



0001:00000000 
0001:00000030 

0003:00001100 
0003:00001104 



^TestSum 
_TestSquare 

_lpCallBackFunc2 
_lpCallBackFuncl 



0a401000 f Algorithms.obj 
Oa401 030 f Algorithms.obj 

0a406 1 00 Algorithms.obj 
0a406 1 04 Algorithms .obj 



15 



When the code inside the .dll makes a "call" to a dereferenced pointer, it would jump to the 
correct function in the outer code and remm the expected return value (if any). For example: 



void CallBackFunction 1 () { 

// This is the first function that exists in the Stub executable 
// whose address has been placed at the appropriate location inside the "dll" code 
20 // that has now been decrypted in a block of memory. The code inside the "dll" 

// makes a function call to this function. In its encrypted state, the "dll" does not contain 
// this address, but merely has a placeholder for the address. The "dll" has enough space 
allocated to hold an 

// address of this size. After the '^dll" has been decrypted at run time, its address is 
25 // placed in that location so the code inside the "dll" that references (or more 

// appropriately dereferences) that address can jump (which is function call) to this 

// address. . . 

AfxMessageBox( 

T("This is the FIRST Stub.exe call back function being called from the dll.")); 
30 return; 

} ' 
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void CallBackFunciion2(DWORD nNumber){ 

// See comment for CallBackFunctionl except this function receives a parameter off 
// of the stack, li could also return a value as well. 
CString 
5 cString( 

K'This is the SECOND Siub.exe call back function being called from the dll'")); 

harbuffer[20]; 
ltoa(nNumber. buffer, 10); 

10 

cString _T(" with a parameter of"); 
cStnng ^= buffer; 
cString ■^=_T("."); 

A6cMessageBox(cString.GetBuffer(0)); 
15 return; 

} 

The outer stub.exe would make the same kinds of jumps or function calls into the now protected 
decrypted code block as follows: 

20 

DWORD c; 

// This command declares a function pointer. This command is different for different function 
// calls. Here the called function takes two integer parameters and 
25 // passes back a DWORD. 

DWORD (♦lpFunc)(DWORD,DWORD); 

// The function pointer is then pointed to tlie starting address of the function in the 
// block of memory that now holds the decrypted DLL. 
30 IpFunc = (DWORD (*)(DWORD,DWORD)) UnwrapFixUpAndRelocateDHO; 

//Now call that "function" which is really like all function calls, i.e.. a jump to 
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// the address where thai function exists. In this case, two 

// variables are passed to that function and returning a value from that function. This function 
illustrates that the function call 
// can be more complicated than merely a simple jump 
5 // to an address. Inline assembler code may be used to push the variables onto 

// the stack frame and return the variable from the eax register, but this function enables 
// the C-^ compiler to do the same function, 
c = (DWORD) (*lpFunc)(a, b); 

10 This mechanism requires the unwrap procedure and the now decrypted code to have intimate 
knowledge about procedural interfaces of each other but no knowledge about each other's 
implementation. This is the way most executable .exe files and .dll files behave but with the 
addition of a series of "wrapper" functions on either side for communication. This method works 
under Windows 95 and Windows NT 4.0 operating systems and should work under Windows NT 

15 3.51 and other operating systems. 

Another modified version of this mechanism that works under the Windows NT 4.0 
operating system because of functions specific to Windows NT 4.0 would be to have another 
hidden and/or encrypted executable within the digital information product. This executable 
would be copied to a physical disk in an unencrypted form, launched or loaded with the 

20 CreateProcessO command in its current form but called with a parameter to load the executable 
in suspended mode: 

BOOL success = CreateProcess(cFrontEndExe.GetBufrer(0), 0, 0, 0, TRUE, 
CREATE_NEW_CONSOLE | CREATE_SUSPENDED, 
25 0, 0, &startUpInfo, &processInfo); 

Then the first process would copy the encrypted dll into its own process and decrypt it, allocate 
enough memory using VirtualAUocExQ in its current form in the second process that has just 
loaded the expendable front end executable in a suspended state as follows: 

30 

LPVOID IpvBlockEx = VirtualAllocEx(processInfo.hProcess, 
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(LPVOID) nPreferredLoadAddress, nPhaniomFileSize. 
MEM^RESERVE | MEM_COMMIT, 
PAGE_READ WRITE); 

The decrypted code is copied from the first process to the second suspended process using 
WriteProcessMemoryO in its current form: 

BOOL bWriteProcessMemory = WriteProcessMemory((HANDLE) processlnfo.hProcess. 
(LPVOID) IpvBlockEx, (LPVOID) nPreferredAddress, 
(DWORD) nPhamomFileSize, (LPDWORD) &nBytes Written); 

Tlie primar>' thread of the previously launched second process is then resumed: 

DWORD nRcsumed = RcsumeThread(processlnfo.hThread); 

Any necessar}' function pointers are then placed in the correct locations by the second process, 
the area of memory is locked to prevent any writes to a swap file, and the memor>' protection is 
changed to execute only as follows: 

Write Address((char*) 0x0a406104, (DWORD) &CallBackFunctionl); 
WriteAddress((char*) 0x0a406100, (DWORD) &CallBackFunction2); 

BOOL bVLock = VirtualLock((LPVOID) nPreferredLoadAddress, nPhantomFileSize); 

DWORD IpflOldProtect; // variable to get old protection 

BOOL bVProtect = VinualProtect((LPVOID) nPreferredLoadAddress, 

nPhantomFileSize, PAGE^EXECUTE, &lpfl01dProtect); 

The program can continue running by making and receiving calls to and from the decrypted 
dynamic link library that now resides in the protected memor>' of its process using commands 
such as the following: 

DWORD c; 
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DWORD (*ipFunc)(DWORD,DWORD); 

IpFunc = (DWORD (*)(DWORD,DWORD)) ExpendableGeiEntryAddress(): 
c = (DWORD) (*lpFuncXa, b); 

5 The first process can either close down or launch another instance of that same process. 

In either of these implementations using the same process or launching into a second 
process, the hidden encrypted code never passes through a file system driver or memor>' resident 
program in decrypted form. Code can be split up among different dynamic link libraries so that 
no two would reside in memory at the same time in order to protect code further. Both of these 

10 systems can be implemented using the Win32 function calls. If additional functions, similar to a 
CreateProcessO command or a LoadLibraryO command but that take a process identifier and 
address location in memory to load in an executable instead of a physical file, are provided in an 
operating system then the entire executable and dynamic link library can be hidden, encrypted, 
and protected on the physical disk and then decrypted within protected memory and use the 

15 operating system loader to load it directly to the operating system from memory without residing 
in decrypted form on any physical medium. 

Having described the operation and use of the computer program product in accordance 
with the invention, embodiments of which are described above in comiection with Figs. 3-8, and 
the operation of the unwrap procedure and device driver it contains, the process of constructing 

20 such a computer program product will now be described in more detail. Referring now to Fig. 9, 
an embodiment of this process for creating a computer program product is shown. This process 
can be applied to any digital information including an arbitrary executable computer program, 
dynamic link libraries and related files of data. All digital information is treated as mere data by 
this process. Each separate data file is combined into a single file by this process, with an 

25 executable program for performing the unwrap procedure, and optionally executable program 
code for a vinual device driver, into the computer program product. Each file of hidden 
information has a unique location and is identified by its own begin and end markers as shown in 
Fig. 3. The first step of this process is opening a new data file for the computer program using a 
name that will be used to indicate an executable file (step 200). For example, an executable 

30 word processing program may be named "word_processor.exe" in the Windows95 operating 
svstem. 
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The three portions of the computer program product are then inserted into the open data 
file. First, the unwap procedure is inserted at the beginning of the file in an executable formal 
step 202. The begin tag for the optional device driver is then inserted in step 204, The 
executable device driver program code is then inserted in step 206, followed by its corresponding 
5 end tag in step 208. For each hidden file to be inserted into this computer program product, steps 
2 1 0 to 2 1 6 are performed. First, the begin tag is inserted in step 210. The begin tag also may 
include an indication of a unique name of the file which will be used as its name in the phantom 
director)' created by the unwrap procedure. The hidden file is then encrypted and/or compressed 
in step 212 and inserted into the data file in step 214. The end tag for the hidden file is then 
10 inserted in step 216. The device driver and all of the tags may be encrypted also if the unwrap 
procedure has suitable decryption procedures. The computer program file is closed when the last 
hidden file is processed. 

Using the present invention digital information, such as executable program code or 
various kinds of data, is loaded and unloaded as needed, and thus does not take up any more 
1 5 memory than is necessary. At no time does unencrypted digital information, such as computer 
program code, exist on disk in accessible and complete decrypted form. Because the original 
digital information is available as a read only file in one embodiment of the invention accessible 
only to the device driver, the digital information may be accessed over networks, from a CD- 
ROM or from a DVD, and can be made to have a limited number of uses. This mechanism is 
20 particularly useful for controlling distribution of computer programs, digitized movies or other 
information while reducing the cost of such distribution and control. For example, software may 
be distributed over a network on a single use basis, and charges may be levied on a per use basis. 
The ability to reverse engineer an application program also may be reduced. 

One benefit with this system over some other systems for preventing unauthorized access 
:5 to digital information is that the content provider maintains control of the encryption applied to 
the information how it may be decrypted. Any need for either a centralized facility or a 
predetermined decryption program is eliminated. An operating systems manufacturer or other 
platform vendor merely provides the capability for tlie information to be accessed and decr>'pted 
on the fly. Since the valuable information and any other tables of authorization codes, 
30 passwords, or hardware identifiers that the content provider may use lo secure the information 
resides in one large encrj^pted file, it becomes difficult, if not impossible, for someone to 
determine just where any of this information exists. 
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A potential scenario with authorization procedure in which the present invention may be 
used is the following. A consumer purchases a DVD disk containing a movie. The user puts the 
disk into the player. This is the first time the disk is installed. The content provider's functions 
are loaded into the DVD chip, which looks in the encrypted table and sees that this is the first 

5 time this disk is being played. The player then displays on a screen a numeric identifier and toll 
free phone number. The consumer calls the toll free phone number and inputs the numeric 
identifier that was displayed on the screen. The content provider provides a numeric password 
based on the numeric identifier that the user inputs into the DVD. The content provider ma\' 
develop a database of information about its consumers that also may be used to detect pirating of 

10 the digital information product. Now that this authorization has taken place, the software that the 
content provider wrote, and is now in the DVD chip, takes a hardware identifier from the DVD 
and encrypts it and puts it in the encrypted and buried table on the disk. Alteratively. the data 
may be decr>'pied in memory and re-encrypted back onto the disk using the hardware identifier 
as part of a key. Now that disk will run and show the movie and will only run on that DVD and 

15 no other. The content provider could allow for a table of hardware id's so they could limit the 
number of DVD\s that disk would run on or a limited number of times it can be shown. It should 
be understood that many other authorization procedures may be used. 

In the foregoing scenario, the movie is encrypted on the same disk inside of the encr>'pted 
file that contains the table and functions the content provider distributed. The movie is decrypted 

20 by the decryption functions contained in the file directly to the DVD chip. At no time does the 
movie reside anywhere in decrypted form. The content provider can protect the movie with any 
desired level of security (for both encryption and authorization). 

In the present invention, the onus of protection of content does not reside with a hardware 
manufacturer or platform provider but in the hands of the content provider. The hardware 

25 manufacturer only provides the mechanism to protect the digital information through the 

operating system. The technique and implementation of protection resides in the hands of the 
content provider. This mechanism allows the content providers to change the level of securit>' as 
needed without any modifications to the hardware. The security of the content is provided by the 
encryption/decryption algorithms, public/private keys, and authorization methods which are 

30 determined by the. content provider. Even each individual product can have its owii 

encryption/decryption algorithms and/or public/private keys. All of these can be changed and 
enhanced as the market demands. 
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The present invention also could be used for on-line or live use of digital information. 
For example, a movie could be retrieved on demand and recorded by a consumer. A set top box 
could receive the digital information, decrypt it, and then re-encrypt and store the information 
using, for example, a hardware identifier of the set top box. Since home movies digitally 

5 recorded would be encrypted using the hardware identifier of the device used in recording, thai 
home movie could not be played on another or only on a limited number of other devices and/or 
for only a specified number of times depending on the wishes of the content provider. Since the 
algorithms are downloaded at the time of recording from a service provider, e.g., the cable 
company, the content provider (movie company) would provide the encrypted data to the service 

10 provider to present to their customers. The service provider need not be concerned with the 

encryption/decryption and authorization functions used by the content provider. Similar uses are 
possible with other data transmission systems including, but not limited to, telephone, cellular 
communications, audio transmission including communication and the like. 

In another embodiment, the stub executable program is a first process that is implemented 

1 5 similar to a debugging tool such as the Softlce debugger fi-om NuMega Technologies or the 
WinDebug debugger from Microsoft Corporation for Ring 0 kernel level debugging for an Intel 
processor based architecture, or the CodeView debugger for ring 3 application level debugging. 
Such a debugger controls execution of a program to be debugged as a second process and steps 
through each program statement or opcode of the debugged program. The debugging tool could 

20 be modified to monitor each opcode that indicates a jump to a program fragment, such as each 
instruction or a block code. If the program fragment to be executed is not decrypted, the 
modified debugger decrypts the program fragment before the jump command is allowed to 
execute. Each program fragment may be re-encrypted after execution. Clearly, unnecessary' 
debugging commands may be omitted from the modified debugger. 

25 Having now described a few embodiments of the invention, it should be apparent to those 

skilled in the art that the foregoing is merely illustrative and not limiting, having been presented 
by way of example only. Numerous modifications and other embodiments are within the scope 
of one of ordinary skill in the an and are contemplated as falling within the scope of the 
invention as defined by the appended claims and equivalent thereto. 
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CLATMS 

1 . A computer-implemented process for executing encrypted computer program logic while 
maintaining protection against copying of conesponding decrypted executable computer 
program logic, wherein the encn'pted computer program logic is stored in association with first 
5 executable computer program logic, the process comprising the steps of: 

through an operating system of a computer, reading, loading and executing the first 
executable computer program logic as a first process having a protected memory area defined by 
the operating system; 

the first process decrypting the encrypted computer program logic into second executable 
10 computer program logic and storing the second executable computer program logic in the 
protected memory area; and 

the first process causing loading and execution of the decrypted second computer 
program logic in the protected memory area. 

15 2. The process of claim 1 , wherein the encrypted computer program logic and the first 
executable computer program logic are stored in a single data file accessible through the 
operating system. 

3, The process of claim 1 , wherein the execution of the decrypted second computer program 
20 logic is performed as a second process having a second protected memory area defined by the 
operating system. 



4. A digital information product including a computer readable medium having digital 
information stored thereon, the digital information including computer program logic defining 
25 first executable computer program logic, wherein the first executable computer program logic 
when executed performs the following steps: 

storing the encrypted computer program logic in a data file accessible through an 
operating system of a computer, wherein the data file also includes first executable computer 
program logic; 

30 through the operating system, reading, loading and executing the first executable 

computer program logic from the data file as a first process having a protected memor>' area; 
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the first process decrypting the encrypted computer program logic into second executable 
computer program logic and storing the second executable computer program logic in the 
protected memory area; and 

the first process causing loading and execution of the decrypted second computer 
5 program logic in the protected memory area. 

5. A computer system comprising: 

a processor for executing computer program logic; 

a main memory operatively connected to the processor for storing digital information 
10 including executable computer program logic at memory locations addressed by the processor; 
and 

an operating system defined by executable computer program logic stored in the memory 
and executed by the processor and having a command which when executed by the processor 
defines means for creating a process in response to a request specifying a process identifier and a 
1 5 memory location in the main memory, wherein the process identifier indicates the process 
making the request and the memory location stores executable computer program logic which 
when executed defines the process. 

6. A computer system having an operating system, for decr>'pting digital information, 
20 comprising: 

means for storing the encrypted computer program logic in a data file accessible tlirough 
the operating system, wherein the data file also includes first executable computer program logic; 

means, invokable through the operating system, for reading, loading and executing the 
first executable computer program logic from the data file as a first process having a protected 
25 memor>' area; 

the first process defining means for decrypting the encrypted computer program logic 
into second executable computer program logic and storing the second executable computer 
program logic in the protected memor>' area; and 

the first process defining means for causing loading and execution of the decrypted 
30 second computer program logic in the protected memor>' area. 
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.7. The computer system of claim 6, wherein the encr>'pted computer program logic and the 
first executable computer program logic are stored in a single data file accessible through the 
operating system. 

5 8. The computer system of claim 6, wherein the execution of the decrypted second computer 
program logic is performed as a second process having a second protected memor\' area defined 
by the operating system, 

9. A digital information product, including a computer readable medium with computer readable 
10 information stored thereon, wherein the computer readable information comprises: 

a first portion of executable computer program logic; and 
a second portion of encrypted digital information; and 

wherein the first portion of executable program logic, when executed, defines means, 
operative in response to requests for digital information, for accessing the second portion of 
15 encrypted digital information, for decrypting the encrypted digital information, and for 
outputting the decrypted digital information. 

1 0. The digital information product of claim 9, wherein the encrypted digital information is 
encrypted executable computer program logic. 

20 

11. A computer program product including a self-decrypting encrypted executable computer 
program, comprising: 

a computer readable medium having computer program logic stored thereon, wherein the 
computer program logic defines: 
25 a first module, 

a second module, 

wherein the first module, when executed by a computer, defines means for loading the 
second module into memory of the computer, and 

a third module defining the encrypted executable computer program. 
30 wherein the second module, when executed by a computer, defines means for 

communicating with an operating system of the computer to receive requests for program code 
from the encrypted executable computer program from the third module, and for processing the 
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requests to access and decrypt the encrypted executable computer program and for providing the 
decrypted executable code from the third module to the operating system. 

12. A process for executing encrypted executable computer programs on a computer system 
5 having a processor, memor\^ and operating system, comprising the steps of: 

receiving computer program logic having a first module defining a start up routine, a 
second module, and a third module containing the encrypted executable computer program; 

executing the first module of the received computer program logic using the processor. 

wherein the step of executing causes the second module to be loaded into the memory of 
10 the computer system, and 

generating requests from the operating system for data from the encrypted executable 
computer program which are received by the second module, and 

accessing and decrypting the encrypted executable computer program and returning the 
decrypted executable computer program to the operating system. 
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